Commit 1d29f21b authored by Soultz's avatar Soultz Committed by helei

ignore ELIMIT for circuit breaker

parent 4e519089
...@@ -15,13 +15,21 @@ ...@@ -15,13 +15,21 @@
// specific language governing permissions and limitations // specific language governing permissions and limitations
// under the License. // under the License.
#include "brpc/circuit_breaker.h"
#include <cmath> #include <cmath>
#include <mutex>
#include <gflags/gflags.h> #include <gflags/gflags.h>
#include <butil/time.h>
#include "brpc/circuit_breaker.h" #include "butil/strings/string_number_conversions.h"
#include "butil/strings/string_split.h"
#include "butil/time.h"
namespace brpc { namespace brpc {
DEFINE_string(circuit_breaker_ignored_error_codes, "2004",
"Comma sparated error code list, those error codes will be ignored by"
"circuit breaker. Note that you should never ignore 0, we ignored ELIMIT for default.");
DEFINE_int32(circuit_breaker_short_window_size, 1500, DEFINE_int32(circuit_breaker_short_window_size, 1500,
"Short window sample size."); "Short window sample size.");
DEFINE_int32(circuit_breaker_long_window_size, 3000, DEFINE_int32(circuit_breaker_long_window_size, 3000,
...@@ -57,6 +65,24 @@ namespace { ...@@ -57,6 +65,24 @@ namespace {
#define EPSILON (FLAGS_circuit_breaker_epsilon_value) #define EPSILON (FLAGS_circuit_breaker_epsilon_value)
std::once_flag g_init_ignored_error_codes_once;
std::set<int> g_ignored_error_codes;
void InitIgoredErrorCodes() {
std::vector<std::string> error_codes;
SplitString(FLAGS_circuit_breaker_ignored_error_codes, ',', &error_codes);
for (const std::string& str : error_codes) {
int error_code = 0;
if (!butil::StringToInt(str, &error_code) || error_code == 0) {
LOG(ERROR) << "Invalid error code '" << str
<< "', check the value of flag 'circuit_breaker_ignored_error_code': "
<< FLAGS_circuit_breaker_ignored_error_codes;
continue;
}
g_ignored_error_codes.insert(error_code);
}
}
} // namepace } // namepace
CircuitBreaker::EmaErrorRecorder::EmaErrorRecorder(int window_size, CircuitBreaker::EmaErrorRecorder::EmaErrorRecorder(int window_size,
...@@ -172,6 +198,10 @@ CircuitBreaker::CircuitBreaker() ...@@ -172,6 +198,10 @@ CircuitBreaker::CircuitBreaker()
} }
bool CircuitBreaker::OnCallEnd(int error_code, int64_t latency) { bool CircuitBreaker::OnCallEnd(int error_code, int64_t latency) {
std::call_once(g_init_ignored_error_codes_once, InitIgoredErrorCodes);
if (g_ignored_error_codes.find(error_code) != g_ignored_error_codes.end()) {
return true;
}
if (_broken.load(butil::memory_order_relaxed)) { if (_broken.load(butil::memory_order_relaxed)) {
return false; return false;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment