All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.smallrye.faulttolerance.api.CircuitBreakerMaintenance Maven / Gradle / Ivy

There is a newer version: 6.4.1
Show newest version
/*
 * Copyright 2020 Red Hat, Inc, and individual contributors.
 *
 * 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 io.smallrye.faulttolerance.api;

import java.util.function.Consumer;

import io.smallrye.common.annotation.Experimental;

/**
 * Allows reading and observing current state of circuit breakers and reseting them to the initial (closed) state.
 * To access a specific circuit breaker, it must be given a name using {@link CircuitBreakerName @CircuitBreakerName}
 * or {@link FaultTolerance.Builder.CircuitBreakerBuilder#name(String) withCircuitBreaker().name("...")}.
 */
@Experimental("first attempt at providing maintenance access to circuit breakers")
public interface CircuitBreakerMaintenance {
    /**
     * Returns current state of the circuit breaker with given {@code name}.
     * Note that there's no guarantee that the circuit breaker will stay in that state for any time,
     * so this method is only useful for monitoring.
     * 

* It is an error to use a {@code name} that wasn't registered using {@link CircuitBreakerName @CircuitBreakerName} * or {@link FaultTolerance.Builder.CircuitBreakerBuilder#name(String) withCircuitBreaker().name("...")}. */ CircuitBreakerState currentState(String name); /** * Registers a {@code callback} to be called when the circuit breaker with given {@code name} * changes state. *

* It is an error to use a {@code name} that wasn't registered using {@link CircuitBreakerName @CircuitBreakerName} * or {@link FaultTolerance.Builder.CircuitBreakerBuilder#name(String) withCircuitBreaker().name("...")}. *

* The callback must be fast and non-blocking and must not throw an exception. */ void onStateChange(String name, Consumer callback); /** * Resets the circuit breaker with given {@code name} to the initial (closed) state. *

* This method should not be used regularly, it's mainly meant for testing (to isolate individual tests) * and perhaps emergency maintenance tasks. *

* It is an error to use a {@code name} that wasn't registered using {@link CircuitBreakerName @CircuitBreakerName} * or {@link FaultTolerance.Builder.CircuitBreakerBuilder#name(String) withCircuitBreaker().name("...")}. */ void reset(String name); /** * Resets all circuit breakers in the application to the initial (closed) state. * This includes all named circuit breakers and unnamed circuit breakers declared using {@code @CircuitBreaker}. * It does not include unnamed circuit breakers created using the programmatic API. *

* This method should not be used regularly, it's mainly meant for testing (to isolate individual tests) * and perhaps emergency maintenance tasks. */ void resetAll(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy