Redis集群配置
pom.xml
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 
 | <dependency><groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-redis</artifactId>
 </dependency>
 <dependency>
 <groupId>org.apache.commons</groupId>
 <artifactId>commons-pool2</artifactId>
 </dependency>
 
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-cache</artifactId>
 </dependency>
 <dependency>
 <groupId>org.ehcache</groupId>
 <artifactId>ehcache</artifactId>
 </dependency>
 <dependency>
 <groupId>javax.cache</groupId>
 <artifactId>cache-api</artifactId>
 </dependency>
 
 | 
application.yml
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 
 | spring:redis:
 timeout: 6000
 password: 123456
 cluster:
 max-redirects: 3
 nodes:
 - 192.168.124.5:7001
 - 192.168.124.5:7002
 - 192.168.124.5:7003
 - 192.168.124.5:7004
 - 192.168.124.5:7005
 - 192.168.124.5:7006
 lettuce:
 pool:
 max-active: 1000
 max-idle: 10
 min-idle: 5
 max-wait: -1
 cache:
 jcache:
 config: classpath:ehcache.xml
 
 | 
RedisConfig.class
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 
 | @Configuration@AutoConfigureAfter(RedisAutoConfiguration.class)
 public class RedisConfig {
 @Bean
 public RedisTemplate<String, Object> redisCacheTemplate(LettuceConnectionFactory redisConnectionFactory) {
 RedisTemplate<String, Object> template = new RedisTemplate<>();
 template.setKeySerializer(new StringRedisSerializer());
 template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
 template.setConnectionFactory(redisConnectionFactory);
 return template;
 }
 }
 
 | 
 Ehcache配置
EhcacheConfig
| 12
 3
 4
 
 | @Configuration@EnableCaching
 public class EhcacheConfig {
 }
 
 | 
ehcache.xml
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 
 | <configxmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
 xmlns='http://www.ehcache.org/v3'
 xmlns:jsr107='http://www.ehcache.org/v3/jsr107'>
 
 <service>
 <jsr107:defaults enable-statistics="true"/>
 </service>
 
 
 <cache alias="defaultCache">
 
 <key-type>java.lang.String</key-type>
 
 <value-type>java.lang.String</value-type>
 
 
 <expiry>
 <ttl unit="seconds">20</ttl>
 </expiry>
 <listeners>
 <listener>
 <class>com.idcmind.ants.listener.CustomCacheEventLogger</class>
 <event-firing-mode>ASYNCHRONOUS</event-firing-mode>
 <event-ordering-mode>UNORDERED</event-ordering-mode>
 <events-to-fire-on>CREATED</events-to-fire-on>
 <events-to-fire-on>UPDATED</events-to-fire-on>
 <events-to-fire-on>EXPIRED</events-to-fire-on>
 <events-to-fire-on>REMOVED</events-to-fire-on>
 <events-to-fire-on>EVICTED</events-to-fire-on>
 </listener>
 </listeners>
 
 <resources>
 
 <heap unit="entries">2000</heap>
 <offheap unit="MB">100</offheap>
 </resources>
 </cache>
 
 
 
 
 <cache-template name="heap-cache">
 <expiry>
 <ttl unit="seconds">20</ttl>
 </expiry>
 <resources>
 <heap unit="entries">2000</heap>
 <offheap unit="MB">100</offheap>
 </resources>
 </cache-template>
 
 
 <cache alias="local" uses-template="heap-cache" />
 
 </config>
 
 | 
CustomCacheEventLogger.java
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 
 | public class CustomCacheEventLogger implements CacheEventListener<Object, Object> {
 private static final Logger LOG = LoggerFactory.getLogger(CustomCacheEventLogger.class);
 
 @Override
 public void onEvent(CacheEvent cacheEvent) {
 LOG.info("缓存监听事件 = {}, Key = {},  Old value = {}, New value = {}", cacheEvent.getType(),
 cacheEvent.getKey(), cacheEvent.getOldValue(), cacheEvent.getNewValue());
 }
 }
 
 | 
CacheService.java
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 
 | @Slf4j@Service
 public class CacheService {
 
 @Autowired
 private RedisTemplate<String, String> redisTemplate;
 
 
 
 
 
 
 @Cacheable(value = "local", key = "#key")
 public String getDataFromLocalCache(String key) {
 return null;
 }
 
 
 
 
 
 
 
 @CachePut(value = "local", key = "#key")
 public String saveData2LocalCache(String key, String value) {
 log.info("缓存到[ehcache]", key, value);
 return value;
 }
 
 
 
 
 
 @CacheEvict(value = "local", key="#key")
 public void delete(String key) {
 
 }
 
 
 
 
 
 
 public String getDataFromRedisCache(String key) {
 String data = redisTemplate.opsForValue().get(key);
 return data;
 }
 
 
 
 
 
 public void saveData2RedisCache(String key, String value) {
 log.info("缓存到[redis]", key, value);
 redisTemplate.opsForValue().set(key, value, 10, TimeUnit.SECONDS);
 }
 
 
 
 
 
 
 public String getDataFromDB(String key) {
 return "【data】= " + key;
 }
 
 }
 
 | 
DataService.java
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 
 | @Slf4j@Service
 public class DataService {
 
 @Autowired
 CacheService cacheService;
 
 public String getData(String key) {
 
 String data = null;
 
 
 data = cacheService.getDataFromRedisCache(key);
 if (!StringUtils.isEmpty(data)) {
 log.info("从[redis]里获取数据: {}", data);
 return data;
 }
 
 
 data = cacheService.getDataFromLocalCache(key);
 if (!StringUtils.isEmpty(data)) {
 log.info("从[ehcache]中获取数据: {}", data);
 
 cacheService.saveData2RedisCache(key, data);
 return data;
 }
 
 
 data = cacheService.getDataFromDB(key);
 if (!StringUtils.isEmpty(data)) {
 log.info("从[db]中获取数据: {}", data);
 
 cacheService.saveData2LocalCache(key, data);
 cacheService.saveData2RedisCache(key, data);
 }
 
 return data;
 }
 }
 
 | 
 单元测试
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 
 | @Slf4j@SpringBootTest
 class CacheServiceTest {
 
 @Autowired
 private DataService dataService;
 
 
 @Test
 void getDataFromLocalCache() throws InterruptedException {
 for (int i=0; i<10; i++) {
 String data = dataService.getData("k1");
 log.info("====================================");
 Thread.sleep(5000);
 }
 }
 }
 
 | 
结果
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 
 | 2020-01-18 18:40:08.025  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[db]中获取数据: 【data】= k12020-01-18 18:40:08.026  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[ehcache]
 2020-01-18 18:40:08.033  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[redis]
 2020-01-18 18:40:08.040  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:13.046  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[redis]里获取数据: 【data】= k1
 2020-01-18 18:40:13.046  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:18.054  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[ehcache]中获取数据: 【data】= k1
 2020-01-18 18:40:18.054  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[redis]
 2020-01-18 18:40:18.061  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:23.070  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[redis]里获取数据: 【data】= k1
 2020-01-18 18:40:23.071  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:28.081  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[db]中获取数据: 【data】= k1
 2020-01-18 18:40:28.081  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[ehcache]
 2020-01-18 18:40:28.082  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[redis]
 2020-01-18 18:40:28.085  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:33.091  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[redis]里获取数据: 【data】= k1
 2020-01-18 18:40:33.092  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:38.097  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[redis]里获取数据: 【data】= k1
 2020-01-18 18:40:38.097  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:43.100  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[ehcache]中获取数据: 【data】= k1
 2020-01-18 18:40:43.101  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[redis]
 2020-01-18 18:40:43.104  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:48.107  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[redis]里获取数据: 【data】= k1
 2020-01-18 18:40:48.107  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 2020-01-18 18:40:53.116  INFO 67416 --- [           main] com.idcmind.ants.service.DataService     : 从[db]中获取数据: 【data】= k1
 2020-01-18 18:40:53.116  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[ehcache]
 2020-01-18 18:40:53.116  INFO 67416 --- [           main] com.idcmind.ants.service.CacheService    : 缓存到[redis]
 2020-01-18 18:40:53.119  INFO 67416 --- [           main] c.idcmind.ants.service.CacheServiceTest  : ====================================
 
 | 
 最后
本文到此结束,感谢阅读。如果您觉得不错,请关注公众号【当我遇上你】,您的支持是我写作的最大动力。