Maison >Java >javaDidacticiel >Partager un exemple d'utilisation de la configuration du cache d'annotation Spring 4.0 + cache Redis

Partager un exemple d'utilisation de la configuration du cache d'annotation Spring 4.0 + cache Redis

Y2J
Y2Joriginal
2017-05-02 14:08:282005parcourir

Cet article présente principalement la configuration détaillée de l'utilisation du cache d'annotation Spring 4.0 + Redis, qui a une certaine valeur de référence. Les amis intéressés peuvent s'y référer

Avant-propos :
<.>

Actuellement, Redis a été construit pour le projet de l'entreprise dans l'architecture technique précédente, mais redis n'est utilisé que pour la gestion de session, mais le cache d'objets en arrière-plan n'est pas utilisé

1. différence entre redis et ehcache :

Après une brève compréhension, je pense personnellement que du point de vue du déploiement, redis est plus adapté au déploiement distribué, tandis qu'ehcache est sur chaque ordinateur. Ouvrez un morceau. de mémoire sur le serveur d'applications pour la mise en cache. Vous devez envisager la mise en cache lorsque Redis n'a pas besoin de prendre en compte la mise en cache. Il peut être déployé sur un serveur séparé (ou dans un serveur d'applications)

2. (spring mvc+maven+mybaits+redis), ici on ne parle que des redis intégrés à Spring :


a. Configurer le fichier pom.xml (si ce n'est pas un projet de gestion maven, téléchargez 2 jars C'est ça. it)

<!-- redis cache related.....start --> 
    <dependency> 
      <groupId>org.springframework.data</groupId> 
      <artifactId>spring-data-redis</artifactId> 
      <version>1.6.0.RELEASE</version> 
    </dependency> 
    <dependency> 
      <groupId>redis.clients</groupId> 
      <artifactId>jedis</artifactId> 
      <version>2.7.3</version> 
    </dependency> 
    <!-- redis cache related.....end -->
b. Configurez le fichier applicationContext.xml


Ajoutez d'abord le cache dans 3c9fdce8078791299ca92e41bddc2b8f

xmlns:cache="http://www.springframework.org/schema/cache" 
xsi:schemaLocation="http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-4.2.xsd"
Chargez dans Spring redis configuration

<!-- ******************** redis缓存  **********************--> 
<!-- 注解一定要配置,不然不起作用 --> 
<cache:annotation-driven /> 
 
<!-- jedis 配置 --> 
  <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig"> 
    <property name="maxIdle" value="${redis.maxIdle}" /> 
    <!--<property name="maxWaitMillis" value="${redis.maxWait}" />--> 
    <property name="testOnBorrow" value="${redis.testOnBorrow}" /> 
  </bean> 
 
  <!-- redis服务器中心 --> 
  <bean id="connectionFactory" 
    class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"> 
    <property name="poolConfig" ref="poolConfig" /> 
    <property name="port" value="${redis.port}" /> 
    <property name="hostName" value="${redis.hostname}" /> 
    <!-- <property name="password" value="${redis.password}" /> --> 
    <property name="timeout" value="${redis.timeout}"></property> 
  </bean> 
   
  <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> 
    <property name="connectionFactory" ref="connectionFactory" /> 
    <property name="keySerializer"> 
      <bean 
        class="org.springframework.data.redis.serializer.StringRedisSerializer" /> 
    </property> 
    <property name="valueSerializer"> 
      <bean 
        class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" /> 
    </property> 
  </bean> 
  <!-- 配置缓存 --> 
  <bean id="cacheManager" class="org.springframework.data.redis.cache.RedisCacheManager"> 
    <constructor-arg ref="redisTemplate" /> 
  </bean> 
   
<!-- ******************** redis缓存  **********************-->
c. Configurer le fichier de ressources application.properties

#redis config 
#redis.hostname=192.168.242.131  
redis.hostname=localhost 
redis.port=6379  
redis.timeout=2000 
redis.usePool=true 
redis.default.db=0 
#\u6700\u5927\u5206\u914D\u7684\u5BF9\u8C61\u6570   
redis.maxTotal=600 
#\u6700\u5927\u80FD\u591F\u4FDD\u6301idel\u72B6\u6001\u7684\u5BF9\u8C61\u6570  
redis.maxIdle=300  
#\u591A\u957F\u65F6\u95F4\u68C0\u67E5\u4E00\u6B21\u8FDE\u63A5\u6C60\u4E2D\u7A7A\u95F2\u7684\u8FDE\u63A5 
redis.timeBetweenEvictionRunsMillis=30000  
#\u7A7A\u95F2\u8FDE\u63A5\u591A\u957F\u65F6\u95F4\u540E\u4F1A\u88AB\u6536\u56DE 
redis.minEvictableIdleTimeMillis=30000  
#\u5F53\u8C03\u7528borrow Object\u65B9\u6CD5\u65F6\uFF0C\u662F\u5426\u8FDB\u884C\u6709\u6548\u6027\u68C0\u67E5  
redis.testOnBorrow=true  
########reids\u7F16\u7801\u683C\u5F0F 
redis.encode=utf-8 
######\u7F13\u5B58\u8FC7\u671F\u65F6\u95F4 \u79D2 1000*60*60*24*7 \u4E03\u5929 
redis.expire=604800000 
####\u662F\u5426\u5F00\u542FRedis\u670D\u52A1\u5E94\u7528 
redis.unlock=false
3. Test

@Service("testService") 
public class TestServiceImpl implements ITestService { 
   
  @Resource 
  private ITestDao testDao; 
 
  @Cacheable(value="testId",key="&#39;id_&#39;+#id") 
  public Test getTestById(int id) { 
    return this.testDao.getObjById(id); 
  } 
   
  @CacheEvict(value="testId",key="&#39;id_&#39;+#id") 
  public void removeTestById(int id) { 
     
  } 
}
Résultat :


La première fois que vous entrez la méthode de service


La deuxième fois que vous n'entrez pas la méthode de service, vous obtenez également la valeur

Remarque : certains amis vous le demanderont, garantie d'erreur au démarrage accès, c'est parce que le service redis local n'a pas été démarré. Téléchargez la version win32/win64, démarrez-la et accédez-y à nouveau, et aucune erreur ne sera signalée

.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn