前言:
目前公司项目在上一个技术架构的处理,已经搭建好了Redis,但redis只用在了做session的管理,然而 后台的对象缓存没有用上
1. redis 和 ehcache的区别:
简单了解了下,个人觉得 从部署上而言,redis更适合分布式部署,ehcache是在每台应用服务器上开辟一块内存做缓存,集群时还得考虑缓存的情况, redis就不需要考虑缓存了、单独部署在一台服务器中(也可以是在某一台应用服务器中)
2. 项目配置(spring mvc+maven+mybaits+redis),这里只讲Spring 集成 redis:
a. 配置 pom.xml 文件 (若不是maven管理项目,下载2个jar 即可 )
<!-- 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.配置 applicationContext.xml文件
先在<beans>中加入 cache缓存
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"
在Spring加载redis配置
<!-- ******************** 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.配置 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 #u6700u5927u5206u914Du7684u5BF9u8C61u6570 redis.maxTotal=600 #u6700u5927u80FDu591Fu4FDDu6301idelu72B6u6001u7684u5BF9u8C61u6570 redis.maxIdle=300 #u591Au957Fu65F6u95F4u68C0u67E5u4E00u6B21u8FDEu63A5u6C60u4E2Du7A7Au95F2u7684u8FDEu63A5 redis.timeBetweenEvictionRunsMillis=30000 #u7A7Au95F2u8FDEu63A5u591Au957Fu65F6u95F4u540Eu4F1Au88ABu6536u56DE redis.minEvictableIdleTimeMillis=30000 #u5F53u8C03u7528borrow Objectu65B9u6CD5u65F6uFF0Cu662Fu5426u8FDBu884Cu6709u6548u6027u68C0u67E5 redis.testOnBorrow=true ########reidsu7F16u7801u683Cu5F0F redis.encode=utf-8 ######u7F13u5B58u8FC7u671Fu65F6u95F4 u79D2 1000*60*60*24*7 u4E03u5929 redis.expire=604800000 ####u662Fu5426u5F00u542FRedisu670Du52A1u5E94u7528 redis.unlock=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 this.testDao.getObjById(id); } @CacheEvict(value="testId",key="'id_'+#id") public void removeTestById(int id) { } }
结果:
第一次 进入Service方法
第二次 不进入service方法 也得到了值
注: 有朋友会问,启动访问时保错, 那是因为本地未启动redis服务, 下载win32/win64版的,启动 再访问就不会报错
以上就是本文的全部内容,希望对大家的学习有所帮助。
发表评论