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
75a80db8
Commit
75a80db8
authored
Mar 23, 2019
by
zhujiashun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
health_check_using_rpc: misc change & update docs
parent
d5bc479e
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
42 additions
and
55 deletions
+42
-55
client.md
docs/cn/client.md
+1
-1
channel.cpp
src/brpc/channel.cpp
+3
-2
controller.cpp
src/brpc/controller.cpp
+1
-1
controller.h
src/brpc/controller.h
+7
-6
load_balancer.h
src/brpc/load_balancer.h
+0
-1
consistent_hashing_load_balancer.cpp
src/brpc/policy/consistent_hashing_load_balancer.cpp
+1
-1
dynpart_load_balancer.cpp
src/brpc/policy/dynpart_load_balancer.cpp
+1
-1
locality_aware_load_balancer.cpp
src/brpc/policy/locality_aware_load_balancer.cpp
+1
-1
randomized_load_balancer.cpp
src/brpc/policy/randomized_load_balancer.cpp
+1
-1
round_robin_load_balancer.cpp
src/brpc/policy/round_robin_load_balancer.cpp
+1
-1
weighted_round_robin_load_balancer.cpp
src/brpc/policy/weighted_round_robin_load_balancer.cpp
+1
-1
selective_channel.cpp
src/brpc/selective_channel.cpp
+1
-2
socket.cpp
src/brpc/socket.cpp
+6
-6
brpc_load_balancer_unittest.cpp
test/brpc_load_balancer_unittest.cpp
+15
-27
brpc_naming_service_filter_unittest.cpp
test/brpc_naming_service_filter_unittest.cpp
+1
-1
brpc_socket_unittest.cpp
test/brpc_socket_unittest.cpp
+1
-2
No files found.
docs/cn/client.md
View file @
75a80db8
...
@@ -242,7 +242,7 @@ locality-aware,优先选择延时低的下游,直到其延时高于其他机
...
@@ -242,7 +242,7 @@ locality-aware,优先选择延时低的下游,直到其延时高于其他机
| ------------------------- | ----- | ---------------------------------------- | ----------------------- |
| ------------------------- | ----- | ---------------------------------------- | ----------------------- |
| health_check_interval (R) | 3 | seconds between consecutive health-checkings | src/brpc/socket_map.cpp |
| health_check_interval (R) | 3 | seconds between consecutive health-checkings | src/brpc/socket_map.cpp |
在默认的配置下,一旦server被连接上,它会恢复为可用状态;brpc还提供了应用层健康检查的机制,协议是Http,只有当Server返回200时,这个server才算恢复,可以通过
-health
\_
check
\_
using
\_
rpc=true来打开这个功能,-health
\_
check
\_
path设置访问的路径(默认访问brpc自带的/health接口
),-health
\_
check
\_
timeout
\_
ms设置超时(默认500ms)。如果在隔离过程中,server从命名服务中删除了,brpc也会停止连接尝试。
在默认的配置下,一旦server被连接上,它会恢复为可用状态;brpc还提供了应用层健康检查的机制,协议是Http,只有当Server返回200时,这个server才算恢复,可以通过
设置-health
\_
check
\_
path来打开这个功能(如果下游也是brpc,推荐设置成/health,服务健康的话会返回200
),-health
\_
check
\_
timeout
\_
ms设置超时(默认500ms)。如果在隔离过程中,server从命名服务中删除了,brpc也会停止连接尝试。
# 发起访问
# 发起访问
...
...
src/brpc/channel.cpp
View file @
75a80db8
...
@@ -556,14 +556,15 @@ int Channel::Weight() {
...
@@ -556,14 +556,15 @@ int Channel::Weight() {
int
Channel
::
CheckHealth
()
{
int
Channel
::
CheckHealth
()
{
if
(
_lb
==
NULL
)
{
if
(
_lb
==
NULL
)
{
SocketUniquePtr
ptr
;
SocketUniquePtr
ptr
;
if
(
Socket
::
Address
(
_server_id
,
&
ptr
)
==
0
&&
!
ptr
->
IsLogOff
()
&&
if
(
Socket
::
Address
(
_server_id
,
&
ptr
)
==
0
&&
!
ptr
->
IsLogOff
()
&&
!
ptr
->
IsHealthCheckingUsingRPC
())
{
!
ptr
->
IsHealthCheckingUsingRPC
())
{
return
0
;
return
0
;
}
}
return
-
1
;
return
-
1
;
}
else
{
}
else
{
SocketUniquePtr
tmp_sock
;
SocketUniquePtr
tmp_sock
;
LoadBalancer
::
SelectIn
sel_in
=
{
0
,
false
,
false
,
0
,
NULL
,
false
};
LoadBalancer
::
SelectIn
sel_in
=
{
0
,
false
,
false
,
0
,
NULL
};
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
return
_lb
->
SelectServer
(
sel_in
,
&
sel_out
);
return
_lb
->
SelectServer
(
sel_in
,
&
sel_out
);
}
}
...
...
src/brpc/controller.cpp
View file @
75a80db8
...
@@ -998,7 +998,7 @@ void Controller::IssueRPC(int64_t start_realtime_us) {
...
@@ -998,7 +998,7 @@ void Controller::IssueRPC(int64_t start_realtime_us) {
}
else
{
}
else
{
LoadBalancer
::
SelectIn
sel_in
=
LoadBalancer
::
SelectIn
sel_in
=
{
start_realtime_us
,
true
,
has_request_code
(),
{
start_realtime_us
,
true
,
has_request_code
(),
_request_code
,
_accessed
,
health_check_call
};
_request_code
,
_accessed
};
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
const
int
rc
=
_lb
->
SelectServer
(
sel_in
,
&
sel_out
);
const
int
rc
=
_lb
->
SelectServer
(
sel_in
,
&
sel_out
);
if
(
rc
!=
0
)
{
if
(
rc
!=
0
)
{
...
...
src/brpc/controller.h
View file @
75a80db8
...
@@ -118,6 +118,8 @@ friend int StreamCreate(StreamId*, Controller&, const StreamOptions*);
...
@@ -118,6 +118,8 @@ friend int StreamCreate(StreamId*, Controller&, const StreamOptions*);
friend
int
StreamAccept
(
StreamId
*
,
Controller
&
,
const
StreamOptions
*
);
friend
int
StreamAccept
(
StreamId
*
,
Controller
&
,
const
StreamOptions
*
);
friend
void
policy
::
ProcessMongoRequest
(
InputMessageBase
*
);
friend
void
policy
::
ProcessMongoRequest
(
InputMessageBase
*
);
friend
void
policy
::
ProcessThriftRequest
(
InputMessageBase
*
);
friend
void
policy
::
ProcessThriftRequest
(
InputMessageBase
*
);
friend
class
OnHealthCheckRPCDone
;
friend
class
HealthCheckManager
;
// << Flags >>
// << Flags >>
static
const
uint32_t
FLAGS_IGNORE_EOVERCROWDED
=
1
;
static
const
uint32_t
FLAGS_IGNORE_EOVERCROWDED
=
1
;
static
const
uint32_t
FLAGS_SECURITY_MODE
=
(
1
<<
1
);
static
const
uint32_t
FLAGS_SECURITY_MODE
=
(
1
<<
1
);
...
@@ -325,12 +327,6 @@ public:
...
@@ -325,12 +327,6 @@ public:
bool
is_done_allowed_to_run_in_place
()
const
bool
is_done_allowed_to_run_in_place
()
const
{
return
has_flag
(
FLAGS_ALLOW_DONE_TO_RUN_IN_PLACE
);
}
{
return
has_flag
(
FLAGS_ALLOW_DONE_TO_RUN_IN_PLACE
);
}
// Tell RPC that this particular call is used to do health check. These two
// functions is used by the developers of brpc and should not be touched or
// called by users.
void
set_health_check_call
(
bool
f
)
{
set_flag
(
FLAGS_HEALTH_CHECK_CALL
,
f
);
}
bool
has_health_check_call
()
const
{
return
has_flag
(
FLAGS_HEALTH_CHECK_CALL
);
}
// ------------------------------------------------------------------------
// ------------------------------------------------------------------------
// Server-side methods.
// Server-side methods.
// These calls shall be made from the server side only. Their results are
// These calls shall be made from the server side only. Their results are
...
@@ -590,6 +586,11 @@ private:
...
@@ -590,6 +586,11 @@ private:
CallId
id
=
{
_correlation_id
.
value
+
nretry
+
1
};
CallId
id
=
{
_correlation_id
.
value
+
nretry
+
1
};
return
id
;
return
id
;
}
}
// Tell RPC that this particular call is used to do health check.
void
set_health_check_call
(
bool
f
)
{
set_flag
(
FLAGS_HEALTH_CHECK_CALL
,
f
);
}
bool
has_health_check_call
()
const
{
return
has_flag
(
FLAGS_HEALTH_CHECK_CALL
);
}
public
:
public
:
CallId
current_id
()
const
{
CallId
current_id
()
const
{
CallId
id
=
{
_correlation_id
.
value
+
_current_call
.
nretry
+
1
};
CallId
id
=
{
_correlation_id
.
value
+
_current_call
.
nretry
+
1
};
...
...
src/brpc/load_balancer.h
View file @
75a80db8
...
@@ -40,7 +40,6 @@ public:
...
@@ -40,7 +40,6 @@ public:
bool
has_request_code
;
bool
has_request_code
;
uint64_t
request_code
;
uint64_t
request_code
;
const
ExcludedServers
*
excluded
;
const
ExcludedServers
*
excluded
;
bool
health_check_call
;
};
};
struct
SelectOut
{
struct
SelectOut
{
...
...
src/brpc/policy/consistent_hashing_load_balancer.cpp
View file @
75a80db8
...
@@ -222,7 +222,7 @@ int ConsistentHashingLoadBalancer::SelectServer(
...
@@ -222,7 +222,7 @@ int ConsistentHashingLoadBalancer::SelectServer(
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
choice
->
server_sock
.
id
))
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
choice
->
server_sock
.
id
))
&&
Socket
::
Address
(
choice
->
server_sock
.
id
,
out
->
ptr
)
==
0
&&
Socket
::
Address
(
choice
->
server_sock
.
id
,
out
->
ptr
)
==
0
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
return
0
;
return
0
;
}
else
{
}
else
{
if
(
++
choice
==
s
->
end
())
{
if
(
++
choice
==
s
->
end
())
{
...
...
src/brpc/policy/dynpart_load_balancer.cpp
View file @
75a80db8
...
@@ -123,7 +123,7 @@ int DynPartLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
...
@@ -123,7 +123,7 @@ int DynPartLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
const
SocketId
id
=
s
->
server_list
[
i
].
id
;
const
SocketId
id
=
s
->
server_list
[
i
].
id
;
if
((
!
exclusion
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
if
((
!
exclusion
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
&&
Socket
::
Address
(
id
,
&
ptrs
[
nptr
].
first
)
==
0
&&
Socket
::
Address
(
id
,
&
ptrs
[
nptr
].
first
)
==
0
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
int
w
=
schan
::
GetSubChannelWeight
(
ptrs
[
nptr
].
first
->
user
());
int
w
=
schan
::
GetSubChannelWeight
(
ptrs
[
nptr
].
first
->
user
());
total_weight
+=
w
;
total_weight
+=
w
;
if
(
nptr
<
8
)
{
if
(
nptr
<
8
)
{
...
...
src/brpc/policy/locality_aware_load_balancer.cpp
View file @
75a80db8
...
@@ -304,7 +304,7 @@ int LocalityAwareLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out)
...
@@ -304,7 +304,7 @@ int LocalityAwareLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out)
}
}
}
else
if
(
Socket
::
Address
(
info
.
server_id
,
out
->
ptr
)
==
0
}
else
if
(
Socket
::
Address
(
info
.
server_id
,
out
->
ptr
)
==
0
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
if
((
ntry
+
1
)
==
n
// Instead of fail with EHOSTDOWN, we prefer
if
((
ntry
+
1
)
==
n
// Instead of fail with EHOSTDOWN, we prefer
// choosing the server again.
// choosing the server again.
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
info
.
server_id
))
{
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
info
.
server_id
))
{
...
...
src/brpc/policy/randomized_load_balancer.cpp
View file @
75a80db8
...
@@ -119,7 +119,7 @@ int RandomizedLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
...
@@ -119,7 +119,7 @@ int RandomizedLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
&&
Socket
::
Address
(
id
,
out
->
ptr
)
==
0
&&
Socket
::
Address
(
id
,
out
->
ptr
)
==
0
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
// We found an available server
// We found an available server
return
0
;
return
0
;
}
}
...
...
src/brpc/policy/round_robin_load_balancer.cpp
View file @
75a80db8
...
@@ -123,7 +123,7 @@ int RoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
...
@@ -123,7 +123,7 @@ int RoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
||
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
id
))
&&
Socket
::
Address
(
id
,
out
->
ptr
)
==
0
&&
Socket
::
Address
(
id
,
out
->
ptr
)
==
0
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
s
.
tls
()
=
tls
;
s
.
tls
()
=
tls
;
return
0
;
return
0
;
}
}
...
...
src/brpc/policy/weighted_round_robin_load_balancer.cpp
View file @
75a80db8
...
@@ -181,7 +181,7 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
...
@@ -181,7 +181,7 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
if
(
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
server_id
)
if
(
!
ExcludedServers
::
IsExcluded
(
in
.
excluded
,
server_id
)
&&
Socket
::
Address
(
server_id
,
out
->
ptr
)
==
0
&&
Socket
::
Address
(
server_id
,
out
->
ptr
)
==
0
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
!
(
*
out
->
ptr
)
->
IsLogOff
()
&&
(
in
.
health_check_call
||
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
()
))
{
&&
!
(
*
out
->
ptr
)
->
IsHealthCheckingUsingRPC
(
))
{
// update tls.
// update tls.
tls
.
remain_server
=
tls_temp
.
remain_server
;
tls
.
remain_server
=
tls_temp
.
remain_server
;
tls
.
position
=
tls_temp
.
position
;
tls
.
position
=
tls_temp
.
position
;
...
...
src/brpc/selective_channel.cpp
View file @
75a80db8
...
@@ -290,8 +290,7 @@ int Sender::IssueRPC(int64_t start_realtime_us) {
...
@@ -290,8 +290,7 @@ int Sender::IssueRPC(int64_t start_realtime_us) {
true
,
true
,
_main_cntl
->
has_request_code
(),
_main_cntl
->
has_request_code
(),
_main_cntl
->
_request_code
,
_main_cntl
->
_request_code
,
_main_cntl
->
_accessed
,
_main_cntl
->
_accessed
};
false
};
ChannelBalancer
::
SelectOut
sel_out
;
ChannelBalancer
::
SelectOut
sel_out
;
const
int
rc
=
static_cast
<
ChannelBalancer
*>
(
_main_cntl
->
_lb
.
get
())
const
int
rc
=
static_cast
<
ChannelBalancer
*>
(
_main_cntl
->
_lb
.
get
())
->
SelectChannel
(
sel_in
,
&
sel_out
);
->
SelectChannel
(
sel_in
,
&
sel_out
);
...
...
src/brpc/socket.cpp
View file @
75a80db8
...
@@ -95,11 +95,11 @@ DEFINE_int32(connect_timeout_as_unreachable, 3,
...
@@ -95,11 +95,11 @@ DEFINE_int32(connect_timeout_as_unreachable, 3,
"times *continuously*, the error is changed to ENETUNREACH which "
"times *continuously*, the error is changed to ENETUNREACH which "
"fails the main socket as well when this socket is pooled."
);
"fails the main socket as well when this socket is pooled."
);
DEFINE_
bool
(
health_check_using_rpc
,
false
,
"By default health check succeeds if server
"
DEFINE_
string
(
health_check_path
,
""
,
"Http path of health check call.
"
"
can be connected. If this flag is set, health check is completed not only
"
"
By default health check succeeds if server can be connected. If this
"
"
when server can be connected but also an additional http call succeeds
"
"
flag is set, health check is completed not only when server can be
"
"
indicated by FLAGS_health_check_path and FLAGS_health_check_timeout_ms"
);
"
connected but also an additional http call succeeds indicated by this"
DEFINE_string
(
health_check_path
,
"/health"
,
"Http path of health check call
"
);
"flag and FLAGS_health_check_timeout_ms
"
);
DEFINE_int32
(
health_check_timeout_ms
,
500
,
"Timeout of health check call"
);
DEFINE_int32
(
health_check_timeout_ms
,
500
,
"Timeout of health check call"
);
static
bool
validate_connect_timeout_as_unreachable
(
const
char
*
,
int32_t
v
)
{
static
bool
validate_connect_timeout_as_unreachable
(
const
char
*
,
int32_t
v
)
{
...
@@ -793,7 +793,7 @@ void Socket::Revive() {
...
@@ -793,7 +793,7 @@ void Socket::Revive() {
}
else
{
}
else
{
LOG
(
INFO
)
<<
"Revived "
<<
*
this
;
LOG
(
INFO
)
<<
"Revived "
<<
*
this
;
}
}
if
(
FLAGS_health_check_using_rpc
)
{
if
(
!
FLAGS_health_check_path
.
empty
()
)
{
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
}
}
return
;
return
;
...
...
test/brpc_load_balancer_unittest.cpp
View file @
75a80db8
...
@@ -205,7 +205,7 @@ void* select_server(void* arg) {
...
@@ -205,7 +205,7 @@ void* select_server(void* arg) {
brpc
::
LoadBalancer
*
c
=
sa
->
lb
;
brpc
::
LoadBalancer
*
c
=
sa
->
lb
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
CountMap
*
selected_count
=
new
CountMap
;
CountMap
*
selected_count
=
new
CountMap
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
uint32_t
rand_seed
=
rand
();
uint32_t
rand_seed
=
rand
();
if
(
sa
->
hash
)
{
if
(
sa
->
hash
)
{
...
@@ -259,7 +259,7 @@ TEST_F(LoadBalancerTest, update_while_selection) {
...
@@ -259,7 +259,7 @@ TEST_F(LoadBalancerTest, update_while_selection) {
// Accessing empty lb should result in error.
// Accessing empty lb should result in error.
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
true
,
0
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
true
,
0
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
ASSERT_EQ
(
ENODATA
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
ENODATA
,
lb
->
SelectServer
(
in
,
&
out
));
...
@@ -555,7 +555,7 @@ TEST_F(LoadBalancerTest, consistent_hashing) {
...
@@ -555,7 +555,7 @@ TEST_F(LoadBalancerTest, consistent_hashing) {
const
size_t
SELECT_TIMES
=
1000000
;
const
size_t
SELECT_TIMES
=
1000000
;
std
::
map
<
butil
::
EndPoint
,
size_t
>
times
;
std
::
map
<
butil
::
EndPoint
,
size_t
>
times
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
::
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
::
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
for
(
size_t
i
=
0
;
i
<
SELECT_TIMES
;
++
i
)
{
for
(
size_t
i
=
0
;
i
<
SELECT_TIMES
;
++
i
)
{
in
.
has_request_code
=
true
;
in
.
has_request_code
=
true
;
...
@@ -632,7 +632,7 @@ TEST_F(LoadBalancerTest, weighted_round_robin) {
...
@@ -632,7 +632,7 @@ TEST_F(LoadBalancerTest, weighted_round_robin) {
// consistent with weight configured.
// consistent with weight configured.
std
::
map
<
butil
::
EndPoint
,
size_t
>
select_result
;
std
::
map
<
butil
::
EndPoint
,
size_t
>
select_result
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
int
total_weight
=
12
;
int
total_weight
=
12
;
std
::
vector
<
butil
::
EndPoint
>
select_servers
;
std
::
vector
<
butil
::
EndPoint
>
select_servers
;
...
@@ -690,15 +690,13 @@ TEST_F(LoadBalancerTest, weighted_round_robin_no_valid_server) {
...
@@ -690,15 +690,13 @@ TEST_F(LoadBalancerTest, weighted_round_robin_no_valid_server) {
// The first socket is excluded. The second socket is logfoff.
// The first socket is excluded. The second socket is logfoff.
// The third socket is invalid.
// The third socket is invalid.
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
exclude
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
exclude
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
EXPECT_EQ
(
EHOSTDOWN
,
wrrlb
.
SelectServer
(
in
,
&
out
));
EXPECT_EQ
(
EHOSTDOWN
,
wrrlb
.
SelectServer
(
in
,
&
out
));
brpc
::
ExcludedServers
::
Destroy
(
exclude
);
brpc
::
ExcludedServers
::
Destroy
(
exclude
);
}
}
TEST_F
(
LoadBalancerTest
,
health_checking_no_valid_server
)
{
TEST_F
(
LoadBalancerTest
,
health_checking_no_valid_server
)
{
// If socket is revived and FLAGS_health_check_using_rpc is set,
// this socket should not be selected.
const
char
*
servers
[]
=
{
const
char
*
servers
[]
=
{
"10.92.115.19:8832"
,
"10.92.115.19:8832"
,
"10.42.122.201:8833"
,
"10.42.122.201:8833"
,
...
@@ -727,7 +725,7 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
...
@@ -727,7 +725,7 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
// Without setting anything, the lb should work fine
// Without setting anything, the lb should work fine
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
}
}
...
@@ -737,7 +735,7 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
...
@@ -737,7 +735,7 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
ptr
->
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
ptr
->
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
// After putting server[0] into health checking state, the only choice is servers[1]
// After putting server[0] into health checking state, the only choice is servers[1]
...
@@ -748,19 +746,22 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
...
@@ -748,19 +746,22 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
ptr
->
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
ptr
->
_health_checking_using_rpc
.
store
(
true
,
butil
::
memory_order_relaxed
);
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
// There is no server available
// There is no server available
ASSERT_EQ
(
EHOSTDOWN
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
EHOSTDOWN
,
lb
->
SelectServer
(
in
,
&
out
));
}
}
// set health_check_call to true, the lb should work fine
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
ids
[
0
].
id
,
&
ptr
));
ptr
->
ResetHealthCheckingUsingRPC
();
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
ids
[
1
].
id
,
&
ptr
));
ptr
->
ResetHealthCheckingUsingRPC
();
// After reset health checking state, the lb should work fine
bool
get_server1
=
false
;
bool
get_server1
=
false
;
bool
get_server2
=
false
;
bool
get_server2
=
false
;
// The probability of 20 consecutive same server is 1 / (2^19)
for
(
int
i
=
0
;
i
<
20
;
++
i
)
{
for
(
int
i
=
0
;
i
<
20
;
++
i
)
{
brpc
::
SocketUniquePtr
ptr
;
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
true
};
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
if
(
ptr
->
remote_side
().
port
==
8832
)
{
if
(
ptr
->
remote_side
().
port
==
8832
)
{
...
@@ -770,19 +771,6 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
...
@@ -770,19 +771,6 @@ TEST_F(LoadBalancerTest, health_checking_no_valid_server) {
}
}
}
}
ASSERT_TRUE
(
get_server1
&&
get_server2
);
ASSERT_TRUE
(
get_server1
&&
get_server2
);
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
ids
[
0
].
id
,
&
ptr
));
ptr
->
ResetHealthCheckingUsingRPC
();
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
ids
[
1
].
id
,
&
ptr
));
ptr
->
ResetHealthCheckingUsingRPC
();
// After reset health checking state, the lb should work fine
for
(
int
i
=
0
;
i
<
4
;
++
i
)
{
brpc
::
SocketUniquePtr
ptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
ptr
);
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
}
delete
lb
;
delete
lb
;
}
}
}
}
...
...
test/brpc_naming_service_filter_unittest.cpp
View file @
75a80db8
...
@@ -53,7 +53,7 @@ TEST_F(NamingServiceFilterTest, sanity) {
...
@@ -53,7 +53,7 @@ TEST_F(NamingServiceFilterTest, sanity) {
ASSERT_EQ
(
0
,
butil
::
hostname2endpoint
(
"10.128.0.1:1234"
,
&
ep
));
ASSERT_EQ
(
0
,
butil
::
hostname2endpoint
(
"10.128.0.1:1234"
,
&
ep
));
for
(
int
i
=
0
;
i
<
10
;
++
i
)
{
for
(
int
i
=
0
;
i
<
10
;
++
i
)
{
brpc
::
SocketUniquePtr
tmp_sock
;
brpc
::
SocketUniquePtr
tmp_sock
;
brpc
::
LoadBalancer
::
SelectIn
sel_in
=
{
0
,
false
,
false
,
0
,
NULL
,
false
};
brpc
::
LoadBalancer
::
SelectIn
sel_in
=
{
0
,
false
,
false
,
0
,
NULL
};
brpc
::
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
brpc
::
LoadBalancer
::
SelectOut
sel_out
(
&
tmp_sock
);
ASSERT_EQ
(
0
,
channel
.
_lb
->
SelectServer
(
sel_in
,
&
sel_out
));
ASSERT_EQ
(
0
,
channel
.
_lb
->
SelectServer
(
sel_in
,
&
sel_out
));
ASSERT_EQ
(
ep
,
tmp_sock
->
remote_side
());
ASSERT_EQ
(
ep
,
tmp_sock
->
remote_side
());
...
...
test/brpc_socket_unittest.cpp
View file @
75a80db8
...
@@ -556,7 +556,6 @@ public:
...
@@ -556,7 +556,6 @@ public:
TEST_F
(
SocketTest
,
health_check_using_rpc
)
{
TEST_F
(
SocketTest
,
health_check_using_rpc
)
{
int
old_health_check_interval
=
brpc
::
FLAGS_health_check_interval
;
int
old_health_check_interval
=
brpc
::
FLAGS_health_check_interval
;
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_using_rpc"
,
"true"
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_path"
,
"/HealthCheckTestService"
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_path"
,
"/HealthCheckTestService"
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_interval"
,
"1"
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_interval"
,
"1"
);
...
@@ -610,7 +609,7 @@ TEST_F(SocketTest, health_check_using_rpc) {
...
@@ -610,7 +609,7 @@ TEST_F(SocketTest, health_check_using_rpc) {
ASSERT_GT
(
cntl
.
response_attachment
().
size
(),
(
size_t
)
0
);
ASSERT_GT
(
cntl
.
response_attachment
().
size
(),
(
size_t
)
0
);
}
}
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_
using_rpc"
,
"false
"
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_
path"
,
"
"
);
char
hc_buf
[
8
];
char
hc_buf
[
8
];
snprintf
(
hc_buf
,
sizeof
(
hc_buf
),
"%d"
,
old_health_check_interval
);
snprintf
(
hc_buf
,
sizeof
(
hc_buf
),
"%d"
,
old_health_check_interval
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_interval"
,
hc_buf
);
GFLAGS_NS
::
SetCommandLineOption
(
"health_check_interval"
,
hc_buf
);
...
...
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