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

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

詳解SpringBoot Redis自適應配置(Cluster Standalone Sentinel)

瀏覽:216日期:2023-05-07 11:53:19

核心代碼段

提供一個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),如果超時就拋異常, 小于零:阻塞不確定的時間, 默認-1 config.setMaxWaitMillis(maxWaitMillis); //最小空閑連接數, 默認0 config.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); // 配置redisTemplate RedisTemplate<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:1003spring.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久久,三上悠亚国产精品一区二区三区
精品国产一区二区三区av片| 日韩va亚洲va欧美va久久| 亚洲一级淫片| 日韩中文字幕视频网| 欧美日韩精品一区二区三区在线观看| 日韩动漫一区| 久久99性xxx老妇胖精品| 日韩黄色大片网站| 免费日韩精品中文字幕视频在线| 亚洲欧美久久精品| 黄色精品视频| 免费不卡中文字幕在线| 91精品久久久久久久久久不卡| 欧美精品一区二区三区精品| 中文一区在线| 老牛国内精品亚洲成av人片| 欧美成人基地 | 国产91一区| 日韩欧美激情| 9999国产精品| 婷婷久久免费视频| 色爱综合网欧美| 免费不卡在线观看| 精品一区二区三区亚洲| 久久亚洲精品中文字幕蜜潮电影| 深夜福利一区| 久久久久久色 | 亚洲一区二区三区久久久| 91精品日本| 国精品一区二区三区| 亚洲综合色婷婷在线观看| 国产日韩欧美三区| 少妇久久久久| 日韩极品在线观看| 亚洲一级高清| 欧美精品国产白浆久久久久| 在线看片福利| 久热综合在线亚洲精品| 精品国产亚洲日本| 亚洲欧美网站在线观看| 国产精品99在线观看| 99精品视频在线| 久久不见久久见国语| 亚洲欧美视频| 久久精品伊人| 亚洲精品人人| 久久精品影视| 麻豆国产精品777777在线| 亚洲精品观看| 首页亚洲欧美制服丝腿| 久久国产影院| 韩国一区二区三区视频| 欧美久久亚洲| 日韩精品三区四区| 亚洲一区二区三区四区五区午夜| 久久精品免视看国产成人| 欧美偷窥清纯综合图区| 99日韩精品| 99国内精品| av资源亚洲| 91精品一区二区三区综合| 日韩一区二区中文| 久久精品高清| 性一交一乱一区二区洋洋av| 国产一区白浆| 一级成人国产| 日韩精品免费视频一区二区三区| 噜噜噜久久亚洲精品国产品小说| 99久久婷婷这里只有精品| 亚洲特色特黄| 婷婷亚洲精品| 国产精品一区二区三区www| 国产精品最新| 婷婷激情一区| 久久国产日本精品| 首页亚洲欧美制服丝腿| 亚洲高清成人| 日韩一区二区免费看| 亚洲综合三区| 国产欧美午夜| 日本一区二区高清不卡| 激情久久久久久久| 日韩午夜在线| 国产精品jk白丝蜜臀av小说| 精品国产欧美| 美女国产精品| 日韩**一区毛片| 亚洲精品国产精品粉嫩| 精品国产三区在线| 午夜精品一区二区三区国产| 国产欧美日韩在线观看视频| 国产精品毛片久久| 免费日本视频一区| 美女视频黄 久久| 久久久久亚洲| 国产欧美91| 激情91久久| 国产精品久久久久久久久妇女| 男人天堂欧美日韩| 亚洲国产影院| 成人国产精品一区二区免费麻豆| 亚洲人www| 最新日韩欧美| 午夜久久影院| 久久一区二区中文字幕| 日韩高清欧美| 国产精品久久久久久久久妇女| 婷婷精品在线| 免费高清在线一区| 亚洲成人三区| 亚洲性视频h| 日韩一区电影| 国产91在线精品| 久久久久久婷| 日韩a一区二区| 综合日韩av| 久久国产精品免费一区二区三区| 国产美女一区| 亚洲人成毛片在线播放女女| 国产超碰精品| 久久一区二区中文字幕| 欧美午夜精品一区二区三区电影| 久久一区二区三区电影| 欧美一区二区三区高清视频| 欧美特黄一级大片| 六月天综合网| 国产精品二区影院| 水蜜桃久久夜色精品一区| 久久精选视频| 免费在线观看成人| 国产欧美日韩一级| 亚洲风情在线资源| 美日韩精品视频| 欧美日韩精品一区二区三区视频 | 电影亚洲精品噜噜在线观看| 日韩精品免费一区二区三区| 五月精品视频| 久久国产精品免费一区二区三区| 高清久久一区| 久热综合在线亚洲精品| 国产精品成人**免费视频| 精品国产第一福利网站| 亚洲中午字幕| 成人在线免费观看网站| 欧美日韩国产在线一区| 国产欧美一区二区三区国产幕精品| 国产在线观看91一区二区三区| 久久中文亚洲字幕| 久久国产尿小便嘘嘘| 久久精品免费一区二区三区| 91精品一区| 国产亚洲一区在线| 久久电影tv| 国产剧情一区二区在线观看| 在线亚洲自拍| 天堂√8在线中文| 国产免费久久| 99视频精品| 欧美天堂视频| 国产精品欧美三级在线观看 | 亚洲一区国产一区| 国产精品高颜值在线观看| 亚洲ab电影| 亚洲色诱最新| 午夜精品婷婷| 91精品在线观看国产| 精品视频亚洲| 国产欧美亚洲一区| 日本不卡视频在线| 免费观看在线综合| 99国产精品视频免费观看一公开| 国产综合色区在线观看| 超级白嫩亚洲国产第一| 国产精品久久久久久久久免费高清| 亚洲免费成人av在线| 国产亚洲在线| 久久亚洲不卡| 蜜臀91精品一区二区三区| 亚洲欧洲一区| 性色一区二区| 中文字幕成人| 最新亚洲国产| 日韩综合小视频| 国产日韩视频在线| 麻豆久久久久久| 久久精品国产99国产| 国产在线观看www| 99精品在线观看| 女主播福利一区| 亚洲麻豆一区| 国产极品久久久久久久久波多结野| 国产亚洲字幕| 特黄毛片在线观看| 99热精品在线观看| 日韩成人精品一区二区三区| 国产欧美日韩一级| 免费观看亚洲| 免费视频最近日韩| 国产精品一级| 欧美一区二区三区高清视频|