Commit 3068ccbf authored by zhujiashun's avatar zhujiashun

health_check_using_rpc: make hc interval exactly -health_check_interval

parent d10699f6
...@@ -1013,6 +1013,8 @@ int HealthCheckChannel::Init(SocketId id, const ChannelOptions* options) { ...@@ -1013,6 +1013,8 @@ int HealthCheckChannel::Init(SocketId id, const ChannelOptions* options) {
class OnAppHealthCheckDone : public google::protobuf::Closure { class OnAppHealthCheckDone : public google::protobuf::Closure {
public: public:
void Run() { void Run() {
butil::Timer tm;
tm.start();
std::unique_ptr<OnAppHealthCheckDone> self_guard(this); std::unique_ptr<OnAppHealthCheckDone> self_guard(this);
SocketUniquePtr ptr; SocketUniquePtr ptr;
const int rc = Socket::AddressFailedAsWell(id, &ptr); const int rc = Socket::AddressFailedAsWell(id, &ptr);
...@@ -1030,7 +1032,12 @@ public: ...@@ -1030,7 +1032,12 @@ public:
} }
RPC_VLOG << "Fail to check path=" << FLAGS_health_check_path RPC_VLOG << "Fail to check path=" << FLAGS_health_check_path
<< ", " << cntl.ErrorText(); << ", " << cntl.ErrorText();
bthread_usleep(interval_s * 1000000); tm.stop();
int64_t sleep_time_ms =
interval_s * 1000 - cntl.latency_us() / 1000 - tm.m_elapsed();
if (sleep_time_ms > 0) {
bthread_usleep(sleep_time_ms * 1000);
}
cntl.Reset(); cntl.Reset();
cntl.http_request().uri() = FLAGS_health_check_path; cntl.http_request().uri() = FLAGS_health_check_path;
ControllerPrivateAccessor(&cntl).set_health_check_call(); ControllerPrivateAccessor(&cntl).set_health_check_call();
...@@ -1060,7 +1067,8 @@ public: ...@@ -1060,7 +1067,8 @@ public:
brpc::ChannelOptions options; brpc::ChannelOptions options;
options.protocol = PROTOCOL_HTTP; options.protocol = PROTOCOL_HTTP;
options.max_retry = 0; options.max_retry = 0;
options.timeout_ms = FLAGS_health_check_timeout_ms; options.timeout_ms =
std::min((int64_t)FLAGS_health_check_timeout_ms, check_interval_s * 1000);
if (done->channel.Init(id, &options) != 0) { if (done->channel.Init(id, &options) != 0) {
LOG(WARNING) << "Fail to init health check channel to SocketId=" << id; LOG(WARNING) << "Fail to init health check channel to SocketId=" << id;
ptr->_ninflight_app_health_check.fetch_sub( ptr->_ninflight_app_health_check.fetch_sub(
......
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