Spring 缓存开发实践 & Redis 集成

Spring 原生的缓存 SimpleCacheManager

配置:类似于 TransactionManager 的配置,参见 Spring 事务 Transaction 开发实践

<bean id="cacheManager" class="SimpleCacheManager">
  <property name="caches">
    <set>
      <!-- 可以设置多个 -->
      <bean class="ConcurrentMapCacheFactoryBean" 
        p:name="students" />
    </set>
  </property>
</bean>

<cache:annotation-driver cache-manager="cacheManager" />

添加缓存@Cachable 注解

@Cachable(value="students")
public List<Student> getStudents() {
  ...
}

更新缓存@CachePut 注解

@CachePut(value="students")
public List<Student> updateStudents() {
  ...
}

删除缓存@CacheEvict 注解

@CacheEvict(value="students", allEntries=true)
public void deleteStudents() {
  ...
}

Redis 介绍

key - value 存储系统(可以存储 string, map, list, set, sorted set),运行在内存中,也可以持久化到磁盘中。

Mac 下的安装
下载 https://redis.io/download
本地解压并移动到 /usr/local

tar zxvf redis-4.0.10.tar.gz
sudo mv redis-4.0.10 /usr/local
cd /usr/local/redis-4.0.10
sudo make test
sudo make install

启动redis-server

启动 Redis

进入命令行与 redis server 进行交互redis-cli

127.0.0.1:6379> set name "Tom"
OK
127.0.0.1:6379> get name
"Tom"
127.0.0.1:6379> lpush students Tom
(integer) 1
127.0.0.1:6379> lpush students Lily
(integer) 2
127.0.0.1:6379> lrange students 0 10
1) "Lily"
2) "Tom"
127.0.0.1:6379> hmset uses name Tom age 25
OK
127.0.0.1:6379> hmget uses name
1) "Tom"

Spring 集成 Redis

redis.properties 配置 Redis 服务器连接信息

redis.host=localhost
redis.port=6379
redis.pass=123456

redis.maxIdle=300
redis.maxActive=600
redis.maxWait=1000
redis.testOnBorrow=true

Spring 配置

<bean id="connectionFactory" class="JedisConnectionFactory" p:host-name="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}" p:pool-config-ref="poolConfig"/>

<bean id="redisTemplate" class="StringRedisTemplate">  
  <property name="connectionFactory" ref="connectionFactory" />  
</bean>

<bean id="cacheManager" class="RedisCacheManager" 
  c:template-ref="redisTemplate"
/>

<cache:annotation-driver cache-manager="cacheManager" />

添加缓存@Cachable 注解

@Cachable(key="#id", value="student")
public Student getStudent(int id) {
  ...
}

更新缓存@CachePut 注解

@CachePut(key="#student.id", value="student")
public void addStudent(Student student) {
  ...
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,259评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,999评论 6 342
  • application的配置属性。 这些属性是否生效取决于对应的组件是否声明为Spring应用程序上下文里的Bea...
    新签名阅读 5,462评论 1 27
  • 昨天,先是看到一个老外,说了一句很震撼的话。 "你个人的项目,应该有四分之一会失败,否则就说明你的冒险精神不够。"...
    茸小呆阅读 844评论 0 2
  • 本文参加#未完待续,就要表白#活动,本人承诺,文章内容为原创,且未在其他平台发表过。 每个人都有一首惊世骇俗的歌在...
    潍科WK阅读 423评论 0 3