Получение JedisConnectionException в одной конкретной операции - PullRequest
0 голосов
/ 18 апреля 2020

Я пытаюсь удалить ключи указанного шаблона c с сервера Redis, но при его выполнении он показывает:

redis.clients.jedis.exceptions.JedisConnectionException: Unexpected end of stream.
    at redis.clients.util.RedisInputStream.ensureFill(RedisInputStream.java:199)
    at redis.clients.util.RedisInputStream.readByte(RedisInputStream.java:40)
    at redis.clients.jedis.Protocol.process(Protocol.java:153)
    at redis.clients.jedis.Protocol.read(Protocol.java:218)
    at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:341)
    at redis.clients.jedis.Connection.getBinaryMultiBulkReply(Connection.java:277)
    at redis.clients.jedis.Jedis.keys(Jedis.java:284)

Для справки, мое значение тайм-аута сервера равно 0 и версия jedis, которая Я использовал это 2.10.2. Ниже приведен фрагмент кода, который я пытаюсь выполнить:

try {
    Set<String> keys = jedis.keys(pattern);
    jedis.del(keys.toArray(new String[keys.size()]));
} catch(Exception e) {
    log.error("Failed to delete key entry for pattern {0}", pattern);
    throw e;
}

здесь шаблон - это строка, которую мы пытаемся удалить.

Есть предложения по устранению ошибки?

================================================= ================

UPDATE-1:

  1. Код работает нормально на локальном уровне, никаких проблем с любой функцией джедаев нет.
  2. При запуске на удаленном сервере другие функции выполняются корректно, кроме этого метода удаления ключей. Именно во время выполнения jedis.keys ()
...