Spring 緩存開發(fā)實踐 & Redis 集成

Spring 原生的緩存 SimpleCacheManager

配置:類似于 TransactionManager 的配置,參見 Spring 事務 Transaction 開發(fā)實踐

<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 存儲系統(tǒng)(可以存儲 string, map, list, set, sorted set),運行在內(nèi)存中,也可以持久化到磁盤中。

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) {
  ...
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,914評論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,948評論 6 342
  • application的配置屬性。 這些屬性是否生效取決于對應的組件是否聲明為Spring應用程序上下文里的Bea...
    新簽名閱讀 5,426評論 1 27
  • 昨天,先是看到一個老外,說了一句很震撼的話。 "你個人的項目,應該有四分之一會失敗,否則就說明你的冒險精神不夠。"...
    茸小呆閱讀 843評論 0 2
  • 本文參加#未完待續(xù),就要表白#活動,本人承諾,文章內(nèi)容為原創(chuàng),且未在其他平臺發(fā)表過。 每個人都有一首驚世駭俗的歌在...
    濰科WK閱讀 393評論 0 3