Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
6cb01912
Commit
6cb01912
authored
Mar 27, 2019
by
zhujiashun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
health_check_using_rpc: wrap HealthCheckTask
parent
5a282109
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
58 additions
and
51 deletions
+58
-51
health_check.cpp
src/brpc/details/health_check.cpp
+20
-4
health_check.h
src/brpc/details/health_check.h
+2
-11
socket.cpp
src/brpc/socket.cpp
+13
-36
socket.h
src/brpc/socket.h
+23
-0
No files found.
src/brpc/details/health_check.cpp
View file @
6cb01912
...
...
@@ -152,10 +152,22 @@ void OnAppHealthCheckDone::Run() {
self_guard
.
release
();
}
HealthCheckTask
::
HealthCheckTask
(
SocketId
id
,
bvar
::
Adder
<
int64_t
>*
nhealthcheck
)
class
HealthCheckTask
:
public
PeriodicTask
{
public
:
explicit
HealthCheckTask
(
SocketId
id
,
SocketVarsCollector
*
nhealthcheck
);
bool
OnTriggeringTask
(
timespec
*
next_abstime
)
override
;
void
OnDestroyingTask
()
override
;
private
:
SocketId
_id
;
bool
_first_time
;
SocketVarsCollector
*
_collector
;
};
HealthCheckTask
::
HealthCheckTask
(
SocketId
id
,
SocketVarsCollector
*
collector
)
:
_id
(
id
)
,
_first_time
(
true
)
,
_
nhealthcheck
(
nhealthcheck
)
{}
,
_
collector
(
collector
)
{}
bool
HealthCheckTask
::
OnTriggeringTask
(
timespec
*
next_abstime
)
{
SocketUniquePtr
ptr
;
...
...
@@ -191,7 +203,7 @@ bool HealthCheckTask::OnTriggeringTask(timespec* next_abstime) {
}
}
(
*
_nhealthcheck
)
<<
1
;
_collector
->
nhealthcheck
<<
1
;
int
hc
=
0
;
if
(
ptr
->
_user
)
{
hc
=
ptr
->
_user
->
CheckHealth
(
ptr
.
get
());
...
...
@@ -200,7 +212,7 @@ bool HealthCheckTask::OnTriggeringTask(timespec* next_abstime) {
}
if
(
hc
==
0
)
{
if
(
ptr
->
CreatedByConnect
())
{
(
*
_nhealthcheck
)
<<
-
1
;
_collector
->
channel_conn
<<
-
1
;
}
if
(
!
FLAGS_health_check_path
.
empty
())
{
ptr
->
_ninflight_app_health_check
.
fetch_add
(
...
...
@@ -225,4 +237,8 @@ void HealthCheckTask::OnDestroyingTask() {
delete
this
;
}
PeriodicTask
*
NewHealthCheckTask
(
SocketId
id
,
SocketVarsCollector
*
collector
)
{
return
new
HealthCheckTask
(
id
,
collector
);
}
}
// namespace brpc
src/brpc/details/health_check.h
View file @
6cb01912
...
...
@@ -21,20 +21,11 @@
#include "brpc/socket_id.h"
#include "brpc/periodic_task.h"
#include "bvar/bvar.h"
#include "brpc/socket.h"
namespace
brpc
{
class
HealthCheckTask
:
public
PeriodicTask
{
public
:
explicit
HealthCheckTask
(
SocketId
id
,
bvar
::
Adder
<
int64_t
>*
nhealthcheck
);
bool
OnTriggeringTask
(
timespec
*
next_abstime
)
override
;
void
OnDestroyingTask
()
override
;
private
:
SocketId
_id
;
bool
_first_time
;
bvar
::
Adder
<
int64_t
>*
_nhealthcheck
;
};
PeriodicTask
*
NewHealthCheckTask
(
SocketId
id
,
SocketVarsCollector
*
collector
);
}
// namespace brpc
...
...
src/brpc/socket.cpp
View file @
6cb01912
...
...
@@ -34,7 +34,6 @@
#include "butil/logging.h" // CHECK
#include "butil/macros.h"
#include "butil/class_name.h" // butil::class_name
#include "bvar/bvar.h"
#include "brpc/log.h"
#include "brpc/reloadable_flags.h" // BRPC_VALIDATE_GFLAG
#include "brpc/errno.pb.h"
...
...
@@ -272,33 +271,11 @@ void Socket::SharedPart::UpdateStatsEverySecond(int64_t now_ms) {
}
}
struct
SocketVarsCollector
{
SocketVarsCollector
()
:
nsocket
(
"rpc_socket_count"
)
,
channel_conn
(
"rpc_channel_connection_count"
)
,
neventthread_second
(
"rpc_event_thread_second"
,
&
neventthread
)
,
nhealthcheck
(
"rpc_health_check_count"
)
,
nkeepwrite_second
(
"rpc_keepwrite_second"
,
&
nkeepwrite
)
,
nwaitepollout
(
"rpc_waitepollout_count"
)
,
nwaitepollout_second
(
"rpc_waitepollout_second"
,
&
nwaitepollout
)
{}
bvar
::
Adder
<
int64_t
>
nsocket
;
bvar
::
Adder
<
int64_t
>
channel_conn
;
bvar
::
Adder
<
int
>
neventthread
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int
>
>
neventthread_second
;
bvar
::
Adder
<
int64_t
>
nhealthcheck
;
bvar
::
Adder
<
int64_t
>
nkeepwrite
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int64_t
>
>
nkeepwrite_second
;
bvar
::
Adder
<
int64_t
>
nwaitepollout
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int64_t
>
>
nwaitepollout_second
;
};
static
SocketVarsCollector
*
s_vars
=
NULL
;
SocketVarsCollector
*
g_vars
=
NULL
;
static
pthread_once_t
s_create_vars_once
=
PTHREAD_ONCE_INIT
;
static
void
CreateVars
()
{
s
_vars
=
new
SocketVarsCollector
;
g
_vars
=
new
SocketVarsCollector
;
}
void
Socket
::
CreateVarsOnce
()
{
...
...
@@ -307,8 +284,8 @@ void Socket::CreateVarsOnce() {
// Used by ConnectionService
int64_t
GetChannelConnectionCount
()
{
if
(
s
_vars
)
{
return
s
_vars
->
channel_conn
.
get_value
();
if
(
g
_vars
)
{
return
g
_vars
->
channel_conn
.
get_value
();
}
return
0
;
}
...
...
@@ -612,7 +589,7 @@ int Socket::Create(const SocketOptions& options, SocketId* id) {
LOG
(
FATAL
)
<<
"Fail to get_resource<Socket>"
;
return
-
1
;
}
s
_vars
->
nsocket
<<
1
;
g
_vars
->
nsocket
<<
1
;
CHECK
(
NULL
==
m
->
_shared_part
.
load
(
butil
::
memory_order_relaxed
));
m
->
_nevent
.
store
(
0
,
butil
::
memory_order_relaxed
);
m
->
_keytable_pool
=
options
.
keytable_pool
;
...
...
@@ -717,7 +694,7 @@ int Socket::WaitAndReset(int32_t expected_nref) {
}
close
(
prev_fd
);
if
(
CreatedByConnect
())
{
s
_vars
->
channel_conn
<<
-
1
;
g
_vars
->
channel_conn
<<
-
1
;
}
}
_local_side
=
butil
::
EndPoint
();
...
...
@@ -861,7 +838,7 @@ int Socket::SetFailed(int error_code, const char* error_fmt, ...) {
if
(
_health_check_interval_s
>
0
)
{
GetOrNewSharedPart
()
->
circuit_breaker
.
MarkAsBroken
();
PeriodicTaskManager
::
StartTaskAt
(
new
HealthCheckTask
(
id
(),
&
s_vars
->
nhealthcheck
),
NewHealthCheckTask
(
id
(),
g_vars
),
butil
::
milliseconds_from_now
(
GetOrNewSharedPart
()
->
circuit_breaker
.
isolation_duration_ms
()));
}
...
...
@@ -997,7 +974,7 @@ void Socket::OnRecycle() {
}
close
(
prev_fd
);
if
(
create_by_connect
)
{
s
_vars
->
channel_conn
<<
-
1
;
g
_vars
->
channel_conn
<<
-
1
;
}
}
reset_parsing_context
(
NULL
);
...
...
@@ -1032,7 +1009,7 @@ void Socket::OnRecycle() {
}
}
s
_vars
->
nsocket
<<
-
1
;
g
_vars
->
nsocket
<<
-
1
;
}
void
*
Socket
::
ProcessEvent
(
void
*
arg
)
{
...
...
@@ -1248,7 +1225,7 @@ int Socket::CheckConnected(int sockfd) {
<<
" via fd="
<<
(
int
)
sockfd
<<
" SocketId="
<<
id
()
<<
" local_port="
<<
ntohs
(
client
.
sin_port
);
if
(
CreatedByConnect
())
{
s
_vars
->
channel_conn
<<
1
;
g
_vars
->
channel_conn
<<
1
;
}
// Doing SSL handshake after TCP connected
return
SSLHandshake
(
sockfd
,
false
);
...
...
@@ -1617,7 +1594,7 @@ FAIL_TO_WRITE:
static
const
size_t
DATA_LIST_MAX
=
256
;
void
*
Socket
::
KeepWrite
(
void
*
void_arg
)
{
s
_vars
->
nkeepwrite
<<
1
;
g
_vars
->
nkeepwrite
<<
1
;
WriteRequest
*
req
=
static_cast
<
WriteRequest
*>
(
void_arg
);
SocketUniquePtr
s
(
req
->
socket
);
...
...
@@ -1657,7 +1634,7 @@ void* Socket::KeepWrite(void* void_arg) {
// Update(8/15/2017): Not working, performance downgraded.
//if (nw <= 0 || req->data.empty()/*note*/) {
if
(
nw
<=
0
)
{
s
_vars
->
nwaitepollout
<<
1
;
g
_vars
->
nwaitepollout
<<
1
;
bool
pollin
=
(
s
->
_on_edge_triggered_events
!=
NULL
);
// NOTE: Waiting epollout within timeout is a must to force
// KeepWrite to check and setup pending WriteRequests periodically,
...
...
@@ -1972,7 +1949,7 @@ int Socket::StartInputEvent(SocketId id, uint32_t events,
// According to the stats, above fetch_add is very effective. In a
// server processing 1 million requests per second, this counter
// is just 1500~1700/s
s
_vars
->
neventthread
<<
1
;
g
_vars
->
neventthread
<<
1
;
bthread_t
tid
;
// transfer ownership as well, don't use s anymore!
...
...
src/brpc/socket.h
View file @
6cb01912
...
...
@@ -37,6 +37,7 @@
#include "brpc/options.pb.h" // ConnectionType
#include "brpc/socket_id.h" // SocketId
#include "brpc/socket_message.h" // SocketMessagePtr
#include "bvar/bvar.h"
namespace
brpc
{
namespace
policy
{
...
...
@@ -126,6 +127,28 @@ struct SocketStat {
uint32_t
out_num_messages_m
;
};
struct
SocketVarsCollector
{
SocketVarsCollector
()
:
nsocket
(
"rpc_socket_count"
)
,
channel_conn
(
"rpc_channel_connection_count"
)
,
neventthread_second
(
"rpc_event_thread_second"
,
&
neventthread
)
,
nhealthcheck
(
"rpc_health_check_count"
)
,
nkeepwrite_second
(
"rpc_keepwrite_second"
,
&
nkeepwrite
)
,
nwaitepollout
(
"rpc_waitepollout_count"
)
,
nwaitepollout_second
(
"rpc_waitepollout_second"
,
&
nwaitepollout
)
{}
bvar
::
Adder
<
int64_t
>
nsocket
;
bvar
::
Adder
<
int64_t
>
channel_conn
;
bvar
::
Adder
<
int
>
neventthread
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int
>
>
neventthread_second
;
bvar
::
Adder
<
int64_t
>
nhealthcheck
;
bvar
::
Adder
<
int64_t
>
nkeepwrite
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int64_t
>
>
nkeepwrite_second
;
bvar
::
Adder
<
int64_t
>
nwaitepollout
;
bvar
::
PerSecond
<
bvar
::
Adder
<
int64_t
>
>
nwaitepollout_second
;
};
struct
PipelinedInfo
{
PipelinedInfo
()
{
reset
();
}
void
reset
()
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment