JedisConnectionException: Could not get a resource from the pool

        最近,使用Redis做缓存时,老是提示JedisConnectionException: Could not get a resource from the pool,Jedis无法从池中获取资源,稍加分析,出现该问题无外乎2种情况:

         1.Jedis 对象用完以后未释放掉,池中无可用资源,所以会出现无法获取新的资源。

         2.JedisPoolConfig中最大连接数maxActive阀值设置的得太小。

        逐一检查:Jedis对象使用完后全部正常close关闭了;JedisPoolConfig中最大连接数maxActive配置为50,目前没有达到最大连接数。

      结论:无解????

     反复检查,选择相信自己,因为使用Redis不止一次了,那么问题就不是Redis的问题,而我的Redis部署在Linux上面,那么就是Linux系统存在问题,再检查一遍,原来如此,真相只有一个,那就是没有使用root登录启动Redis,马上su切换到root,重启Redis,OK了。

问题总结:

        运维部署Redis时,使用的是root进行操作,于是,当使用其他非root用户启动Redis时,表面上Redis启动成功,没有任何提示,实际上,Redis根本没有权限读取配置文件,创建临时文件,所以Redis启动成功但是无法正常工作,所以报错。

        记住:Redis启动成功,用ps aux |grep redis查看进程正常,没有报错,但不一定工作正常,这个设计逻辑没有毛病! 

你可能感兴趣的:(Java牛逼,jedis,redis,exception,java)