redis在java中的客户端连接

本文详细介绍了如何在单例模式下使用JedisPool创建Redis连接池,并实现了断线重连机制。通过设置最大活跃连接数、最大空闲连接数、最大等待时间以及连接验证策略,确保了应用程序在Redis连接断开时能够自动重新建立连接,提高了系统的稳定性和可靠性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单例模式下创建连接池,包括断线重连等机制。

public class RedisClient {

private static JedisPool pool = null; 
private RedisClient(){

initial();
}
private static RedisClient client = new RedisClient();
public static RedisClient getClient(){
return client;
}

private void initial() {
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
jedisPoolConfig.setMaxActive(30000);
jedisPoolConfig.setMaxIdle(600);
jedisPoolConfig.setMaxWait(1000);
jedisPoolConfig.setTestOnBorrow(true);
if (pool == null) { 
try {
pool = new JedisPool(jedisPoolConfig, "10.0.201.140", 5379,4000000);
} catch (Exception e) {
e.printStackTrace();
pool.destroy();
initial();//断线重连
} 
} 
} 
/**
* 获取redis连接的 Pipelined
* @return
*/
public synchronized jedis getJedis() { 
Jedis jd = null;
try {
jd= pool.getResource();
} catch (Exception e) {
if(jd!=null){
pool.returnBrokenResource(jd);
}
e.printStackTrace();
jd = getJedis();//递归进行断线重连
} 
return jd;
} 
/** 
* 释放被损坏的jedis. 
* 
* @param jd 
*/ 
public synchronized void releaseBrokenJedis(Jedis jd) { 
pool.returnBrokenResource(jd); 
jd = null; 
} 

/** 
* 从连接池中释放jedis 
* 
* @param jd 
*/ 
public synchronized void releaseJedis(Jedis jd) { 
pool.returnResource(jd); 
jd = null; 
} 
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值