日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SpringBoot Redis自適應配置的實現(Cluster Standalone Sentinel)

瀏覽:232日期:2023-03-14 16:09:58
核心代碼段

提供一個JedisConnectionFactory 根據配置來判斷 單點 集群 還是哨兵

@Bean @ConditionalOnMissingBean public JedisConnectionFactory jedisConnectionFactory() {JedisConnectionFactory factory = null; String[] split = node.split(',');Set<HostAndPort> nodes = new LinkedHashSet<>();for (int i = 0; i < split.length; i++) { try {String[] split1 = split[i].split(':');nodes.add(new HostAndPort(split1[0], Integer.parseInt(split1[1]))); } catch (Exception e) {throw new RuntimeException(String.format('出現配置錯誤!請確認node=[%s]是否正確', node)); }}//獲得默認的連接池構造器(怎么設計的,為什么不抽象出單獨類,供用戶使用呢) 有毒JedisClientConfiguration.JedisPoolingClientConfigurationBuilder jpcb =(JedisClientConfiguration.JedisPoolingClientConfigurationBuilder) JedisClientConfiguration.builder();//指定jedisPoolConifig來修改默認的連接池構造器(真麻煩,濫用設計模式!) !!!!jpcb.poolConfig(jedisPoolConfig);//通過構造器來構造jedis客戶端配置JedisClientConfiguration jedisClientConfiguration = jpcb.build(); //如果是哨兵的模式if (!StringUtils.isEmpty(sentinel)) { logger.info('Redis use SentinelConfiguration'); RedisSentinelConfiguration redisSentinelConfiguration = new RedisSentinelConfiguration(); String[] sentinelArray = sentinel.split(','); for (String s : sentinelArray) {try { String[] split1 = s.split(':'); redisSentinelConfiguration.addSentinel(new RedisNode(split1[0], Integer.parseInt(split1[1])));} catch (Exception e) { throw new RuntimeException(String.format('出現配置錯誤!請確認node=[%s]是否正確', node));} } factory = new JedisConnectionFactory(redisSentinelConfiguration, jedisClientConfiguration); }//如果是單個節點 用Standalone模式else if (nodes.size() == 1) { logger.info('Redis use RedisStandaloneConfiguration'); for (HostAndPort n : nodes) {RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();if (!StringUtils.isEmpty(password)) { redisStandaloneConfiguration.setPassword(RedisPassword.of(password));}redisStandaloneConfiguration.setPort(n.getPort());redisStandaloneConfiguration.setHostName(n.getHost());factory = new JedisConnectionFactory(redisStandaloneConfiguration, jedisClientConfiguration); }}//集群配置信息實現else { logger.info('Redis use RedisStandaloneConfiguration'); RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration(); nodes.forEach(n -> {redisClusterConfiguration.addClusterNode(new RedisNode(n.getHost(), n.getPort())); }); if (!StringUtils.isEmpty(password)) {redisClusterConfiguration.setPassword(RedisPassword.of(password)); } redisClusterConfiguration.setMaxRedirects(maxRedirect); factory = new JedisConnectionFactory(redisClusterConfiguration, jedisClientConfiguration);}return factory; }Configration

import com.fasterxml.jackson.annotation.JsonAutoDetect;import com.fasterxml.jackson.annotation.PropertyAccessor;import com.fasterxml.jackson.databind.ObjectMapper;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Value;import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;import org.springframework.cache.Cache;import org.springframework.cache.CacheManager;import org.springframework.cache.annotation.CachingConfigurerSupport;import org.springframework.cache.annotation.EnableCaching;import org.springframework.cache.interceptor.CacheErrorHandler;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.cache.RedisCacheManager;import org.springframework.data.redis.connection.*;import org.springframework.data.redis.connection.jedis.JedisClientConfiguration;import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;import org.springframework.data.redis.serializer.RedisSerializer;import org.springframework.data.redis.serializer.StringRedisSerializer;import org.springframework.util.StringUtils;import redis.clients.jedis.HostAndPort;import redis.clients.jedis.JedisPoolConfig; import java.util.LinkedHashSet;import java.util.Set; /** * @Author foxzzz * @Class SelfAdaptionRedisConfig * @Description 自適應redis配置 * 適用于 單點[主從] 哨兵模式 集群模式 * @Date 2020/7/6 14:34 */ @Configuration@EnableCachingpublic class SelfAdaptionRedisConfig<K, V> extends CachingConfigurerSupport { private final static Logger logger = LoggerFactory.getLogger(SelfAdaptionRedisConfig.class); @Value('${spring.redis.node}') private String node; @Value('${spring.redis.timeout:0}') private int timeout; @Value('${spring.redis.password:}') private String password; @Value('${spring.redis.sentinel:}') private String sentinel; @Value('${spring.redis.jedis.pool.max-total:8}') private int maxTotal; @Value('${spring.redis.jedis.pool.max-idle:8}') private int maxIdle; @Value('${spring.redis.jedis.pool.min-idle:0}') private int minIdle; @Value('${spring.redis.jedis.pool.max-wait:-1}') private long maxWaitMillis; @Value('${spring.redis.jedis.pool.test-on-borrow:true}') private boolean testOnBorrow; @Value('${spring.redis.jedis.factory.max-redirects:5}') private int maxRedirect; @Autowired private JedisPoolConfig jedisPoolConfig; @Autowired private JedisConnectionFactory jedisConnectionFactory; @Bean @ConditionalOnMissingBean @Override public CacheManager cacheManager() {// 初始化緩存管理器,在這里我們可以緩存的整體過期時間什么的,我這里默認沒有配置logger.info('初始化 -> [{}]', 'CacheManager RedisCacheManager Start');RedisCacheManager.RedisCacheManagerBuilder builder = RedisCacheManager.RedisCacheManagerBuilder.fromConnectionFactory(jedisConnectionFactory);return builder.build(); } @Bean @ConditionalOnMissingBean @Override public CacheErrorHandler errorHandler() {// 異常處理,當Redis發生異常時,打印日志,但是程序正常走logger.info('初始化 -> [{}]', 'Redis CacheErrorHandler');CacheErrorHandler cacheErrorHandler = new CacheErrorHandler() { @Override public void handleCacheGetError(RuntimeException e, Cache cache, Object key) {logger.error('Redis occur handleCacheGetError:key -> [{}]', key, e); } @Override public void handleCachePutError(RuntimeException e, Cache cache, Object key, Object value) {logger.error('Redis occur handleCachePutError:key -> [{}];value -> [{}]', key, value, e); } @Override public void handleCacheEvictError(RuntimeException e, Cache cache, Object key) {logger.error('Redis occur handleCacheEvictError:key -> [{}]', key, e); } @Override public void handleCacheClearError(RuntimeException e, Cache cache) {logger.error('Redis occur handleCacheClearError:', e); }};return cacheErrorHandler; } @Bean @ConditionalOnMissingBean public JedisPoolConfig jedisPoolConfig() {JedisPoolConfig config = new JedisPoolConfig();// 獲取連接時的最大等待毫秒數(如果設置為阻塞時BlockWhenExhausted),如果超時就拋異常, 小于零:阻塞不確定的時間, 默認-1config.setMaxWaitMillis(maxWaitMillis);//最小空閑連接數, 默認0config.setMinIdle(minIdle);// 最大空閑連接數, 默認8個config.setMaxIdle(maxIdle);// 最大連接數, 默認值8個config.setMaxTotal(maxTotal);//對拿到的connection進行validateObject校驗config.setTestOnBorrow(testOnBorrow);return config; } // private JedisCluster getJedisCluster() {//String[] split = node.split(',');//Set<HostAndPort> nodes = new LinkedHashSet<>();//for (int i = 0; i < split.length; i++) {// try {//String[] split1 = split[i].split(':');//nodes.add(new HostAndPort(split1[0], Integer.parseInt(split1[1]))));// } catch (Exception e) {// }//}//JedisCluster jedisCluster = null;//if (StringUtils.isEmpty(password)) {// jedisCluster = new JedisCluster(nodes, 5000, 3000, 10, jedisPoolConfig);//} else {// jedisCluster = new JedisCluster(nodes, 5000, 3000, 10, password, jedisPoolConfig);//}// } @Bean @ConditionalOnMissingBean public JedisConnectionFactory jedisConnectionFactory() {JedisConnectionFactory factory = null; String[] split = node.split(',');Set<HostAndPort> nodes = new LinkedHashSet<>();for (int i = 0; i < split.length; i++) { try {String[] split1 = split[i].split(':');nodes.add(new HostAndPort(split1[0], Integer.parseInt(split1[1]))); } catch (Exception e) {throw new RuntimeException(String.format('出現配置錯誤!請確認node=[%s]是否正確', node)); }}//獲得默認的連接池構造器(怎么設計的,為什么不抽象出單獨類,供用戶使用呢) 有毒JedisClientConfiguration.JedisPoolingClientConfigurationBuilder jpcb =(JedisClientConfiguration.JedisPoolingClientConfigurationBuilder) JedisClientConfiguration.builder();//指定jedisPoolConifig來修改默認的連接池構造器(真麻煩,濫用設計模式!) !!!!jpcb.poolConfig(jedisPoolConfig);//通過構造器來構造jedis客戶端配置JedisClientConfiguration jedisClientConfiguration = jpcb.build(); //如果是哨兵的模式if (!StringUtils.isEmpty(sentinel)) { logger.info('Redis use SentinelConfiguration'); RedisSentinelConfiguration redisSentinelConfiguration = new RedisSentinelConfiguration(); String[] sentinelArray = sentinel.split(','); for (String s : sentinelArray) {try { String[] split1 = s.split(':'); redisSentinelConfiguration.addSentinel(new RedisNode(split1[0], Integer.parseInt(split1[1])));} catch (Exception e) { throw new RuntimeException(String.format('出現配置錯誤!請確認node=[%s]是否正確', node));} } factory = new JedisConnectionFactory(redisSentinelConfiguration, jedisClientConfiguration); }//如果是單個節點 用Standalone模式else if (nodes.size() == 1) { logger.info('Redis use RedisStandaloneConfiguration'); for (HostAndPort n : nodes) {RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();if (!StringUtils.isEmpty(password)) { redisStandaloneConfiguration.setPassword(RedisPassword.of(password));}redisStandaloneConfiguration.setPort(n.getPort());redisStandaloneConfiguration.setHostName(n.getHost());factory = new JedisConnectionFactory(redisStandaloneConfiguration, jedisClientConfiguration); }}//集群配置信息實現else { logger.info('Redis use RedisStandaloneConfiguration'); RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration(); nodes.forEach(n -> {redisClusterConfiguration.addClusterNode(new RedisNode(n.getHost(), n.getPort())); }); if (!StringUtils.isEmpty(password)) {redisClusterConfiguration.setPassword(RedisPassword.of(password)); } redisClusterConfiguration.setMaxRedirects(maxRedirect); factory = new JedisConnectionFactory(redisClusterConfiguration, jedisClientConfiguration);}return factory; } @Bean @ConditionalOnMissingBean public RedisTemplate<String, Object> redisTemplate(JedisConnectionFactory jedisConnectionFactory) {//設置序列化Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);// 配置redisTemplateRedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();redisTemplate.setConnectionFactory(jedisConnectionFactory);RedisSerializer stringSerializer = new StringRedisSerializer();// key序列化redisTemplate.setKeySerializer(stringSerializer);// value序列化redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());//redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);// Hash key序列化redisTemplate.setHashKeySerializer(stringSerializer);// Hash value序列化redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);redisTemplate.afterPropertiesSet();return redisTemplate; }}pom依賴

<dependencies><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <version>${springboot.version}</version></dependency><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> <scope>provided</scope></dependency><dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>${redis.version}</version></dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <scope>provided</scope></dependency><dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <scope>provided</scope></dependency><dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <scope>provided</scope></dependency> </dependencies>配置文件

1.yml配置

1.1支持 Cluster模式 集群

node有多個redis的地址,以逗號分隔 如果redis沒有密碼直接去掉配置就可以了 yml配置

spring: redis: node: 127.0.0.1:1001,127.0.0.1:1002,127.0.0.1:1003 password: 123456

properties配置

spring.redis.node=127.0.0.1:1001,127.0.0.1:1002,127.0.0.1:1003 spring.redis.password=123456

1.2支持 Standalone模式 單點

node里只有一個redis地址的時候,會自動變成單點模式 yml配置

spring: redis: node: 127.0.0.1:1001 password: 123456

properties配置

spring.redis.node=127.0.0.1:1001spring.redis.password=123456

1.3支持 Sentinel模式 哨兵

當配置上sentinel以后就變成了哨兵模式 多個哨兵可以以逗號分割 yml配置

spring: redis: node: 127.0.0.1:1001 sentinel:127.0.0.1:1002,127.0.0.1:1003 password: 123456

properties配置

spring.redis.node=127.0.0.1:1001spring.redis.sentinel:127.0.0.1:1002,127.0.0.1:1003spring.redis.password=123456

1.4覆蓋默認配置

如果沒有配置這些信息,就會走默認配置 也可以在properties或者yml覆蓋默認配置

#最大連接數, 默認值8個spring.redis.jedis.pool.max-total=8#最大空閑連接數, 默認8個spring.redis.jedis.pool.max-idle=8#最小空閑連接數, 默認0spring.redis.jedis.pool.min-idle=0#獲取連接時的最大等待毫秒數,如果超時就拋異常, 小于零:阻塞不確定的時間, 默認-1spring.redis.jedis.pool.max-wait=-1#對拿到的connection進行validateObject校驗spring.redis.jedis.pool.test-on-borrow=true#集群時最大重定向個數默認5spring.redis.jedis.factory.max-redirects=5使用

代碼使用

@Autowired private RedisTemplate<String, Object> redisTemplate;

到此這篇關于SpringBoot Redis自適應配置的實現(Cluster Standalone Sentinel)的文章就介紹到這了,更多相關SpringBoot Redis自適應配置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品一区二区不卡| 91久久久精品国产| 午夜天堂精品久久久久| 日本在线不卡视频| 日韩三级精品| 欧美aaaaaa午夜精品| 极品av在线| 亚洲二区在线| 视频一区二区不卡| 青青草国产精品亚洲专区无| 国产精品亚洲一区二区在线观看| 精品国产乱码久久久| 日韩精品专区| 另类中文字幕国产精品| 99国产精品99久久久久久粉嫩| 日韩精品免费视频人成| 97视频热人人精品免费| 红桃视频欧美| 久久亚洲精精品中文字幕| 亚洲不卡av不卡一区二区| 日本国产欧美| 欧美色图一区| 麻豆国产精品一区二区三区| 午夜日韩av| 岛国精品一区| 欧美一区在线观看视频| 九九综合在线| 国产精品久久久久蜜臀| 99国产精品私拍| 久久精品日韩欧美| 中文精品视频| 人人草在线视频| 国产视频网站一区二区三区| 国产精品88久久久久久| 精品国产成人| 欧美亚洲国产日韩| 蜜桃免费网站一区二区三区| 国产91一区| 亚洲性色av| 成年男女免费视频网站不卡| 国产精品伊人| 日本精品国产| 中文字幕日韩亚洲| 久久国产主播| 久久久久久网| 美女视频黄 久久| 国产欧美丝祙| 国产精品天天看天天狠| 亚洲精品一区二区在线播放∴| 欧美激情国产在线| 久久精品国产99国产精品| 国产调教一区二区三区| 国产免费播放一区二区| 日韩国产精品久久久久久亚洲| 亚洲精品极品| 婷婷综合一区| 91亚洲精品在看在线观看高清| 日韩一区二区三区四区五区| 日欧美一区二区| 亚洲免费一区二区| 国产亚洲综合精品| 国产模特精品视频久久久久| 免费日韩精品中文字幕视频在线| 麻豆精品91| 91精品一区| 免费在线亚洲欧美| 亚洲风情在线资源| 久久人人99| 亚洲午夜免费| 国产精品www.| 98精品视频| 免费观看在线综合色| 欧美三级第一页| 成人国产精品一区二区免费麻豆| 精品视频在线观看网站| 成人看片网站| 视频精品一区| 91亚洲成人| 亚洲视频播放| 欧美91在线| 亚洲精品91| 国产日韩欧美一区二区三区在线观看 | bbw在线视频| 91成人精品| 国产极品一区| 日韩精品一区第一页| 国产精品一区二区精品视频观看 | 国产剧情在线观看一区| 91精品国产一区二区在线观看| 久久成人高清| 天堂网在线观看国产精品| 国产日产精品_国产精品毛片 | 91tv亚洲精品香蕉国产一区| 亚洲精品在线国产| 91精品蜜臀一区二区三区在线| 最新日韩欧美| 国产a久久精品一区二区三区| 噜噜噜躁狠狠躁狠狠精品视频 | 不卡中文字幕| 福利在线免费视频| 国产探花在线精品| 美女久久一区| 97se综合| 欧美国产精品| 欧美日韩视频免费看| 亚洲欧美不卡| 美女少妇全过程你懂的久久| 国产精品白丝久久av网站| 亚洲人成网站在线在线观看| 国产一区日韩一区| 欧美成a人国产精品高清乱码在线观看片在线观看久| 综合亚洲自拍| 一区二区三区网站| 日韩精品一二三| 91精品国产乱码久久久久久久| 欧美日韩午夜| 蜜臀久久久久久久| 日韩精品影视| 香蕉视频亚洲一级| 中文在线а√在线8| 日韩精品久久久久久| 午夜在线精品| 久久国产精品99国产| 美女久久一区| 午夜性色一区二区三区免费视频| 亚洲免费影院| 性欧美69xoxoxoxo| 天堂va蜜桃一区二区三区| 爽好久久久欧美精品| 亚洲啊v在线免费视频| 久久国内精品| 国产精品日本一区二区不卡视频 | 日日摸夜夜添夜夜添国产精品| 亚洲另类视频| 国产精品蜜月aⅴ在线| 国产999精品在线观看| 国产传媒av在线| 五月综合激情| 久久国产视频网| 国产欧美大片| 国产一区二区久久久久| 日韩亚洲在线| 日本在线不卡视频| 美腿丝袜亚洲一区| 国产福利片在线观看| 午夜久久一区| 国产精品啊啊啊| 美女毛片一区二区三区四区| 日韩久久99| 日韩深夜视频| 蜜桃伊人久久| 日韩.com| 日韩精品三区四区| 日韩精品欧美| 日本视频一区二区| 99久久99久久精品国产片果冰| 中文一区一区三区免费在线观| 国产精品宾馆| 亚洲日韩视频| 久久中文字幕av| 毛片不卡一区二区| 日本亚洲欧美天堂免费| 91久久久精品国产| 精品视频高潮| 日韩1区2区3区| 亚洲欧美日本国产专区一区| 成人国产精品| 国产精品theporn| 午夜天堂精品久久久久| 色88888久久久久久影院| 日韩不卡在线观看日韩不卡视频| 欧美精品高清| 在线观看一区| 国产一区白浆| 免费观看不卡av| 日韩av在线中文字幕| 91精品国产自产在线丝袜啪| 在线 亚洲欧美在线综合一区| 欧美aⅴ一区二区三区视频| 丝袜亚洲精品中文字幕一区| 亚洲不卡系列| 九九精品调教| 国产精品伦一区二区| 国产欧美日韩在线一区二区| 午夜久久黄色| 中文字幕在线视频久| 国产精品视频一区二区三区| 日韩中出av| 亚洲精一区二区三区| 一本综合精品| 日韩精品免费一区二区夜夜嗨| 在线综合视频| 亚洲精品福利| 四虎精品永久免费| 91亚洲精品视频在线观看| 69堂精品视频在线播放| 欧美一区成人| 国产乱码精品| 日产午夜精品一线二线三线| 精品资源在线|