JedisConnectionException:流错误的意外结束

JedisConnectionException: Unexpected end of stream error

我正在尝试执行 rpush 操作并遇到以下错误:

redis.clients.jedis.exceptions.JedisConnectionException: Unexpected end of stream.
    at redis.clients.util.RedisInputStream.ensureFill(RedisInputStream.java:199) ~[jedis-2.9.0.jar:na]
    at redis.clients.util.RedisInputStream.readByte(RedisInputStream.java:40) ~[jedis-2.9.0.jar:na]
    at redis.clients.jedis.Protocol.process(Protocol.java:151) ~[jedis-2.9.0.jar:na]
    at redis.clients.jedis.Protocol.read(Protocol.java:215) ~[jedis-2.9.0.jar:na]
    at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:340) ~[jedis-2.9.0.jar:na]
    at redis.clients.jedis.Connection.getIntegerReply(Connection.java:265) ~[jedis-2.9.0.jar:na]
    at redis.clients.jedis.Jedis.rpush(Jedis.java:865) ~[jedis-2.9.0.jar:na]
    at

有解决此错误的想法吗?

请提供代码片段并确认您使用的 Jedis 版本(我猜是 2.9.0)。

以前,Jedis 有同样的问题(与超时配置有关)。

此处有更多详细信息:

https://github.com/xetorthio/jedis/issues/1029

https://github.com/xetorthio/jedis/issues/932

原因是服务器设置超时非零,这意味着在一段时间后连接被处理或关闭。所以客户端从池中获取连接,但之后它就无效了!

解决方法是: 将服务器上的超时设置为 0 要么 不要在客户端保留池 -> GenericObjectPoolConfig.setMaxIdle(0) 所以每次连接服务器时,客户端都会从池中获取一个新连接而不是旧连接

就我而言,我有一个本地 Redis Server 6,Jedis 使用 host=localhost 或 host=127.0.0.1 进行连接,但是当我尝试进行 jedis 连接 ping 时,它会抛出 JedisConnectionException。

如果您有相同的行为,请检查您的 redis 服务器是否正常工作。连接 redis-cli 并使用您在 jedis 中拥有的相同主机和端口执行 ping。

如果您收到“PONG”响应,那没关系,但如果您收到“连接被对等方重置”之类的内容,则需要更改您的服务器绑定。 在我将绑定地址更改为 0.0.0.0 后,它对我有用。

使用 docker、Redis 服务器 6 和 redis 客户端的示例:

  1. 配置文件redis.conf(绑定<>或绑定0.0.0.0):

bind 0.0.0.0
protected-mode yes
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize no
supervised no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
databases 16
always-show-logo yes
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
rdb-del-sync-files no
dir ./
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
oom-score-adj no
oom-score-adj-values 0 200 800
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
jemalloc-bg-thread yes
  1. 运行 Redis 服务器:

#!/bin/bash
MSYS_NO_PATHCONV=1 docker run -d --rm --name redis -p 6379:6379 -v $(pwd)/redis.conf:/redis.conf redis redis-server /redis.conf
  1. 运行 Redis 客户端:

docker run -it --network=host --rm redis redis-cli -h 127.0.0.1
  1. 测试连接:

127.0.0.1:6379> ping
PONG

之后,检查您的 jedis 配置以使用相同的 IP 和端口,这应该可以解决问题。