Feature - CLUSTERDOWN error handling. #2831

pull/2853/head
Nikita Koksharov 5 years ago
parent e11c1e14ba
commit 52f786ed54

@ -0,0 +1,32 @@
/**
* Copyright (c) 2013-2020 Nikita Koksharov
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.redisson.client;
/**
* This error occurs when Redis Cluster is down.
*
* @author Nikita Koksharov
*
*/
public class RedisClusterDownException extends RedisException {
private static final long serialVersionUID = -2565335188503354660L;
public RedisClusterDownException(String message) {
super(message);
}
}

@ -357,6 +357,9 @@ public class CommandDecoder extends ReplayingDecoder<State> {
} else if (error.startsWith("NOAUTH")) { } else if (error.startsWith("NOAUTH")) {
data.tryFailure(new RedisAuthRequiredException(error data.tryFailure(new RedisAuthRequiredException(error
+ ". channel: " + channel + " data: " + data)); + ". channel: " + channel + " data: " + data));
} else if (error.startsWith("CLUSTERDOWN")) {
data.tryFailure(new RedisClusterDownException(error
+ ". channel: " + channel + " data: " + data));
} else { } else {
if (data != null) { if (data != null) {
data.tryFailure(new RedisException(error + ". channel: " + channel + " command: " + LogHelper.toString(data))); data.tryFailure(new RedisException(error + ". channel: " + channel + " command: " + LogHelper.toString(data)));

@ -426,7 +426,8 @@ public class RedisExecutor<V, R> {
} }
if (attemptFuture.cause() instanceof RedisLoadingException if (attemptFuture.cause() instanceof RedisLoadingException
|| attemptFuture.cause() instanceof RedisTryAgainException) { || attemptFuture.cause() instanceof RedisTryAgainException
|| attemptFuture.cause() instanceof RedisClusterDownException) {
if (attempt < attempts) { if (attempt < attempts) {
onException(); onException();
connectionManager.newTimeout(new TimerTask() { connectionManager.newTimeout(new TimerTask() {

Loading…
Cancel
Save