`
Everyday都不同
  • 浏览: 714246 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resourc

阅读更多

使用redis作为缓存工具,很容易出现从redis连接池中得不到连接的问题。而使用redis连接池获取连接的时候,往往是在高并发情形下,出现如题所示的问题。本人一般从如下几个方面排查,经验之谈~

 

1)首先判断redis连接参数是否配置正确?很有可能,之前一直能取,但现在突然出现异常,很有可能是redis的服务器down掉了,或者redis的连接条件被更改;

2)网络权限更改:做过项目就很容易知道,每种环境的权限是不同的,很有可能你项目所在的网段连接redis的权限被更改,导致之前一直可以获取redis连接,但现在却无法获取。

3)查代码:一般而言,从redis里面获取连接取数据,完毕之后应该立即归还到池中。应该注意的是,一般都会用典型的try{}  catch{} finally{}结构包围,在finally{}中释放连接(这样可以确保无论是否发生异常,redis的连接都能及时被归还到连接池中);

4)归还redis连接必须要注意的一点,如:

//从连接池获取连接
Jedis jedis = pool.getResource();
try{
   
}catch(Exception e) {
    e.printStackTrace();
}finally{
   //归还连接到redis池中
   poo.returnResource();
}

 这段代码看起来很满足3)的规范,在finally里归还了连接。但!有一个隐藏的容错性考虑,当Jedis jedis = pool.getResource();这段代码发生异常时,finally的代码是不会被执行的。我可以模拟一下,

 

 

String str = null;
System.out.println(str.length());//模拟异常
try{
	System.out.println("模拟从redis取数据");
}catch(Exception e) {
	e.printStackTrace();
}finally{
	System.out.println("连接释放。。。");
}

 运行报异常,finally里面的代码不会被执行。所以,应该改成这样:

 

 

//从连接池获取连接
Jedis jedis = null;
try{
   jedis = pool.getResource();
}catch(Exception e) {
    e.printStackTrace();
}finally{
   //归还连接到redis池中
   poo.returnResource();
}

 当然,这是由于try catch finally的机制决定,但很容易被忽视~

 

5)关闭redis的持久化,提高redis的存取性能:当使用redis缓存的数据越来越多的时候,可以考虑关闭redis的持久化功能。具体做法是:修改redis配置文件,注释掉原来的持久化规则,将redis.conf代码

save 900 1

save 300 10

save 60 10000

注释,修改为 save " ",然后重启redis服务器即可~

 

再不济的话,提高redis池连接个数和最大空闲数等参数……

 

 

1
0
分享到:
评论

相关推荐

    jedis-2.8.0-API文档-中文版.zip

    Maven坐标:redis.clients:jedis:2.8.0; 标签:clients、jedis、redis、jar包、java、API文档、中文版; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中...

    Redis连接超时异常的处理方法

    Exception in thread “main” redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out  at redis.clients.util.RedisInputStream.ensureFill...

    redis.clients.jedis_REDIS_API

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。

    详解Redis开启远程登录连接

    redis.clients.jedis.exceptions.JedisConnectionException: java.net.ConnectException: Connection refused: connect at redis.clients.jedis.Connection.connect(Connection.java:164) at redis.clients.jedis....

    jedis-2.4.1.jar、redis.clients-3.0.1.jar、jedis-3.0.0.jar

    jedis-2.4.1.jar、redis.clients-3.0.1.jar、jedis-3.0.0.jar 全量包,可用!

    jedis调用redis源码Demo

    import redis.clients.jedis.exceptions.JedisConnectionException; public class FirestJedisTest { private static Jedis jedis = new Jedis("127.0.0.1"); public void testConn() { try { jedis....

    redis,jedis 需要的jar包

    使用Java操作Redis需要jedis-2.1.0.jar,如果需要使用Redis连接池的话,还需commons-pool-1.5.4.jar使用Java操作Redis需要jedis-2.1.0.jar,如果需要使用Redis连接池的话,还需commons-pool-1.5.4.jar

    Redis Java客户端Jedis 2.9.0 jar包(含common-pool2)

    Redis的官方推荐Java客户端...import redis.clients.jedis.Jedis; Jedis jedis = new Jedis("localhost"); jedis.set("foo", "bar"); String value = jedis.get("foo"); jedis.close(); System.out.println(value);

    redis.conf Redis配置文件下载

    redis.conf Redis配置文件 下载 redis.conf 配置详解 Redis配置文件redis.conf 详解1.基本配置内存单位的表示# 1k => 1000 bytes# ...Redis 的详细介绍Redis 的下载地址

    redis.conf-6.0

    redis.conf 6.0版本配置文件

    redis.conf-5.0

    redis.conf 5.0版本配置文件

    redis6.2.6 redis.conf配置文件

    redis6.2.6 redis.conf配置文件

    redis.conf

    正确的redis.conf文件分享。Linux系统搭建redis集群,需要修改redis.conf里的端口号,当前文件端口号为7001.

    redis.goredis.goredis.goredis.goredis.go

    redis.goredis.goredis.go

    redis.conf配置文件下载

    redis.conf配置文件下载

    save-mysql-redis.py

    save_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql_redis.pysave_mysql...

    php_redis.dll适用于php5.5

    php_redis.dll适用于php5.5,php的redis扩展文件,找了很久才找到适用于php5.5的

    spring-data-redis-1.6.0.RELEASE.jar + jedis-2.7.2.jar

    spring-data-redis-1.6.0.RELEASE.jar + jedis-2.7.2.jar,另:相关的配置文件在我的代码片段中

    阿里云Redis.docx

    阿里云Redis.docx阿里云Redis.docx阿里云Redis.docx阿里云Redis.docx阿里云Redis.docx

    jedis-2.9.0-API文档-中文版.zip

    对应Maven信息:groupId:redis.clients,artifactId:jedis,version:2.9.0 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释...

Global site tag (gtag.js) - Google Analytics