我在完成.hgetall()考试时遇到了问题,下面是我尝试过的:
Jedis jedis = new Jedis(REDIS_MASTER_NODE);
jedis.connect();
jedis.configSet("timeout", "30");
Map<String, String> alreadyStored = jedis.hgetAll(redisTargetHash);下面是我得到的结果:
Exception in thread "main" redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out
at redis.clients.jedis.Protocol.process(Protocol.java:79)
at redis.clients.jedis.Protocol.read(Protocol.java:131)
at redis.clients.jedis.Connection.getBinaryMultiBulkReply(Connection.java:199)
at redis.clients.jedis.Jedis.hgetAll(Jedis.java:851)这就解决了这个问题:
Jedis jedis = new Jedis(REDIS_MASTER_NODE, 6379, 1800);发布于 2013-02-21 19:12:43
如果你想要做的是设置Jedis连接timeout,你应该使用专门的构造函数来完成:
public Jedis(final String host, final int port, final int timeout)您正在做的是从Jedis设置Redis设置的超时。执行CONFIG SET timeout 60,意味着Redis将在60秒后关闭空闲的客户端连接。这就是为什么你会在Jedis中得到异常。
发布于 2015-02-12 08:10:28
这是xetorthio的答案的一个扩展,但这里是用于JedisPool的类似方法。(警告:这是基于我直接查看Jedis版本2.6.2代码的理解,并未在实际用例中进行测试。)
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
jedisPoolConfig.setMaxWaitMillis(writeTimeout);
JedisPool pool = new JedisPool(jedisPoolConfig, redisHost, port, readTimeout);writeTimeout是池中的Jedis资源等待写入操作的最长时间。
为池构造函数指定的readTimeout是套接字读取的等待时间,有关更多详细信息,请参见java.net.Socket.setSoTimeout。
发布于 2016-07-15 03:34:23
需要考虑的几件事:
int redis.clients.jedis.Protocol.DEFAULT_TIMEOUT = 2000 [0x7d0]https://stackoverflow.com/questions/14993644
复制相似问题