redis.clients.jedis.exceptions.JedisConnectionException:连接到Redis集群时无法从池中获取资源

时间:2018-10-25 13:15:28

标签: java docker redis

我正在尝试使用Java JedisCluster 客户端连接到Redis集群。

首先,我使用此docker映像制作了Redis集群

grokzen/redis-cluster

创建了6个节点(3个主节点和3个从节点)

在Windows中使用docker计算机,我使用此命令启动了Redis集群

docker run -p 7000:7000 -p 7001:7001 -p 7002:7002 -p 7003:7003 -p 7004:7004 -p 7005:7005 -p 7006:7006 -p 7007:7007 dockerImageId

Redis群集开始简短日志:

  
    

使用3个母版:

         

172.17.0.2:7000

         

172.17.0.2:7001

         

172.17.0.2:7002

  
     

将副本172.17.0.2:7004添加到172.17.0.2:7000添加副本   172.17.0.2:7005

     

到172.17.0.2:7001添加副本

     
    

172.17.0.2:7003至172.17.0.2:7002

  

Redis群集的Java客户端:

Set<HostAndPort> jedisClusterNodes = new HashSet<HostAndPort>();
        jedisClusterNodes.add(new HostAndPort("192.168.99.100", 7000));
        JedisCluster jc = new JedisCluster(jedisClusterNodes);
        jc.set("key", "Redis-Val");
        String value = jc.get("key");
        System.out.println("key is : "+value);

运行此代码后,出现此异常

  

线程“主”中的异常   redis.clients.jedis.exceptions.JedisConnectionException:无法获取   来自池中的资源   redis.clients.util.Pool.getResource(Pool.java:53)在   redis.clients.jedis.JedisPool.getResource(JedisPool.java:226)在   redis.clients.jedis.JedisSlotBasedConnectionHandler.getConnectionFromSlot(JedisSlotBasedConnectionHandler.java:66)     在   redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:116)     在   redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:141)     在   redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:141)     在   redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:141)     在   redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:141)     在   redis.clients.jedis.JedisClusterCommand.run(JedisClusterCommand.java:31)     在redis.clients.jedis.JedisCluster.set(JedisCluster.java:103)处   redis.redis_example.App.main(App.java:20)由以下原因引起:   redis.clients.jedis.exceptions.JedisConnectionException:   java.net.SocketTimeoutException:连接超时

我已经通过telnet命令检查了redis是否正在集群中的任何节点上运行:

  

telnet 192.168.99.100 7000

连接成功

1 个答案:

答案 0 :(得分:0)

我通过在运行容器时设置IP env变量来解决它:

docker run -d -p 7000-7005:7000-7005 -e "IP=0.0.0.0" grokzen/redis-cluster:latest