Redis之—— Spring4.0 注解Cache+Redis缓存

时间:2025-02-14 08:35:14

转载请注明出处:/l1028386804/article/details/70833786

前言:
      目前公司项目在上一个技术架构的处理,已经搭建好了Redis,但redis只用在了做session的管理,然而后台的对象缓存没有用上

 1. redis 和 ehcache的区别

       简单了解了下,个人觉得 从部署上而言,redis更适合分布式部署,ehcache是在每台应用服务器上开辟一块内存做缓存,集群时还得考虑缓存的情况, redis就不需要考虑缓存了、单独部署在一台服务器中(也可以是在某一台应用服务器中)

 2. 项目配置

这里只讲Spring 集成 redis:
   a. 配置 文件  (若不是maven管理项目,下载2个jar 即可 )

<!-- redis cache related.....start -->
<dependency>
	<groupId></groupId>
	<artifactId>spring-data-redis</artifactId>
	<version>1.6.</version>
</dependency>
<dependency>
	<groupId></groupId>
	<artifactId>jedis</artifactId>
	<version>2.7.3</version>
</dependency>
<!-- redis cache related.....end -->
b.配置 文件
  先在<beans>中加入 cache缓存
xmlns:cache="/schema/cache"
xsi:schemaLocation="/schema/cache /schema/cache/spring-cache-4."
在Spring加载redis配置
 <!-- ******************** redis缓存   **********************-->
<!-- 注解一定要配置,不然不起作用 -->
<cache:annotation-driven />


<!-- jedis 配置 -->
<bean  class="">
    <property name="maxIdle" value="${}" />
    <!--<property name="maxWaitMillis" value="${}" />-->
    <property name="testOnBorrow" value="${}" />
</bean>

<!-- redis服务器中心 -->
<bean 
    class="">
    <property name="poolConfig" ref="poolConfig" />
    <property name="port" value="${}" />
    <property name="hostName" value="${}" />
    <!-- <property name="password" value="${}" /> -->
    <property name="timeout" value="${}"></property>
</bean>

<bean  class="">
    <property name="connectionFactory" ref="connectionFactory" />
    <property name="keySerializer">
        <bean
            class="" />
    </property>
    <property name="valueSerializer">
        <bean
            class="" />
    </property>
</bean>
<!-- 配置缓存 -->
<bean  class="">
    <constructor-arg ref="redisTemplate" />
</bean>

<!-- ******************** redis缓存   **********************-->
c.配置 资源文件
#redis config
=localhost
=6379  
=2000
=true
=0  
=600 
=300 
=30000  
=30000 
=true 
=utf-8
=604800000
=false

3. 测试

@Service("testService")
public class TestServiceImpl implements ITestService {
    
    @Resource
    private ITestDao testDao;

    @Cacheable(value="testId",key="'id_'+#id")
    public Test getTestById(int id) {
        return (id);
    }
    
    @CacheEvict(value="testId",key="'id_'+#id")
    public void removeTestById(int id) {
        
    }
}

结果:

  第一次 进入Service方法

  第二次 不进入service方法 也得到了值