1.redis client使ç¨å°ç»
2.进阶篇Redis实战之Redisson使用技巧详解
3.Spring Data Redis切换底层Jedis 和 Lettuce实现
redis client使ç¨å°ç»
æ¬æè®°å½äºä½¿ç¨redis clientçåºæ¬é ç½®åè¿æ¥è¶ éçé®é¢
java端çredis client使ç¨çæ¯jedisï¼ä»çè¿æ¥æ± å®ç°æ¯åºäºApache Commons Pool 2ï¼é ç½®ä¹åèçGenericObjectPoolConfigï¼åå«æ¯minIdle,maxIdle,maxTotal,å ¶ä¸maxTotalå å«äºæ´»è·åéæ´»è·çè¿æ¥æ»æ°
å¦å¤timeoutæ¯å¨Jedisçæé å½æ°éæå®çï¼ä»åæ¶æå®äºconnectionTimeout(æ大è¿æ¥æ¶é´)åsoTimeout(æ大ååºæ¶é´ )
客æ·ç«¯é 置就ä¸é¢å 个ï¼ç¨èµ·æ¥è¿æ¯æºç®åçï¼ä½æ¯ç¨çè¿ç¨ä¸è¿æ¯ä¼éå°ä¸äºé®é¢ï¼æ¯å¦ERR max number of clients reachedï¼æå¯è½ä¼æ¯ä»¥ä¸å 个åå ï¼
redis serveræ大è¿æ¥æ°çé ç½®ç±maxclientså³å®ï¼2.6以åççæ¬é»è®¤å¼æ¯ï¼å¦æ设置çå¼è¶ è¿äºæä½ç³»ç»çæ大å¼éå¶ï¼åä¼å¨å¯å¨çæ¶åç»åºæ示
ä¸è¬æ åµä¸ï¼è¶ è¿çæ大è¿æ¥æ°æ¯ä½¿ç¨ä¸çé®é¢ãé¦å redisæå¡ç«¯é»è®¤çtimouté ç½®çæ¯0ï¼å³ä¸ä¼å ³éè¿æ¥ï¼å³ä¾¿è¿ä¸ªè¿æ¥å·²ç»ç©ºé²å¾ä¹ ï¼è¿æ¶åå¦æ客æ·ç«¯å¨éå¯å没æå ³éè¿æ¥æè 说ä¸é´æé²ç«å¢ä¹ç±»çæå¼äºè¿æ¥ï¼redis æå¡ç«¯å°ä¼æ°¸ä¹ ä¿çè¿äºè¿æ¥ï¼è¿æ¶ååªè¦é ç½®timeoutå³å¯
é¤äºtimeoutä¹è¿å¯ä»¥éè¿keepaliveé ç½®æ¥è§£å³ï¼æ¯å¦å¦æä½ çredisè§è²æ¯sentinelï¼é£ä¹rediséçtimeoutçé ç½®æ¯ä¸çæçã
è¿éçkeepaliveæçæ¯TCPåè®®å±çé ç½®ï¼ä»æä¸ä¸ªåæ°å½±åï¼
è¿æ¥è¶ æ¶å ¬å¼ä¸ºï¼
è¿ä¸ªæ¶é´è¿æ¯æºä¹ çï¼redisæå¡ç«¯å¨3.2çæ¬å·²ç»ä»¥åï¼é»è®¤è®¾ç½®äºtcp_keepalive_time为ç§(以åççæ¬é»è®¤ä¸º0ï¼ä¹å°±æ¯ä¸å¯ç¨)
é ç½®ä¸è¿ä¸ªåæ°ä¹åï¼å¯¹äºä¸äºå®¢æ·ç«¯æ²¡ææ£å¸¸å ³éçåºæ¯ä¹è½åæ¶çå ³é
å¦å¤è¯´å°å®¢æ·ç«¯çæ£ç¡®é ç½®ï¼å¦ææ¯ä½¿ç¨Springçè¯ï¼åªè¦é ç½®ä¸beançdestroy-methodï¼å¨è¿éå ³éè¿æ¥æ± å³å¯ï¼å¦æ没æç¨Springï¼åè¦èªå·±æ³¨åä¸ä¸ªShutdownHook
1. redisæ¥-ERR max number of clients reachedé误
2. Custom Configuration of TCP Socket Keep-Alive Timeouts
3. Redis Clients Handling
4. Sentinelæ大è¿æ¥æ°
进阶篇Redis实战之Redisson使用技巧详解
进阶篇Redis实战之Redisson使用技巧详解 Redisson,作为基于Redis的Java数据网格客户端,提供了超越Jedis、Lettuce等基础封装的功能。它不仅涵盖了Redis的基本数据结构操作,如字符串、乐淘科技 源码哈希、列表、集合、有序集合和布隆过滤器,还扩展了分布式服务,如分布式锁、远程服务和任务调度等。访问Redisson的更多详情,可参考其GitHub文档。天空荣耀版 源码 要开始使用Redisson,首先在Maven项目中添加其依赖,然后根据不同场景创建RedissonClient实例,如单机环境下的简单配置。接着,我们逐步探索Redisson的特性:通过RBucket操作字符串,支持设置值和有效期
利用RMap处理哈希,fizz网关源码分析存储对象需实现Serializable
RList用于列表操作,RSet和RSortedSet分别处理集合和有序集合,需实现Comparable接口
Redisson的RBloomFilter支持布隆过滤器,具有高效查询但有误识别风险
分布式自增ID和全局唯一ID生成,解决分库分表后的问题
分布式锁是Redisson的核心功能,包括简单使用和集群环境下的RedissonRedLock
在集群环境中,Redisson支持哨兵模式和主从模式配置。shadowsock易语言源码对比Jedis和Lettuce,Redisson不仅提供底层操作,还构建了分布式解决方案,与Lettuce结合使用能更全面满足需求。 在实际生产环境中,推荐使用简单单点方案解决分布式锁问题,复杂情况下,买副图源码RedissonRedLock是个不错的选择。更多深入内容,可以参考相关文章如Redisson开发文档和作者的文章分享。Spring Data Redis切换底层Jedis 和 Lettuce实现
Spring Data Redis提供了对Redis操作的高级抽象,支持Jedis和Lettuce两种连接方式。通过简单的配置即可连接Redis并切换连接方式。具体步骤如下:
引入Redis依赖使用Spring Boot的spring-boot-starter-data-redis。
自定义配置类设置Key和Value的序列化。
修改Redis连接配置,可自由切换单节点、哨兵模式和集群模式。
注入RedisTemplate后,即可操作Redis。RedisTemplate具有两个泛型。
源码分析部分,从Redis自动配置类RedisAutoConfiguration开始,它引入了两个连接Redis配置类:LettuceConnectionConfiguration和JedisConnectionConfiguration。这两个配置类通过条件注解控制是否生效,如果生效,则会使用相应的依赖生成RedisConnectionFactory的Bean。引入Lettuce依赖时,能通过io.lettuce.core.RedisClient找到类,说明默认使用Lettuce。若无Jedis相关依赖,则当前配置类无效。
切换连接方式至Jedis有两种方式:利用@ConditionalOnClass注解排除Lettuce依赖,或利用@ConditionalOnProperty注解修改配置文件中的spring.redis.client-type为jedis。第一种方式优点在于不加载多余的依赖包,推荐使用。第二种方式则可通过配置文件自由切换连接方式。
本文由OpenWrite平台发布。请按照上述步骤进行Spring Data Redis的使用和连接方式切换。