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
b17bcc8b
Commit
b17bcc8b
authored
Apr 03, 2019
by
zhujiashun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
revived_from_all_failed: fix UT
parent
593082c4
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
33 additions
and
19 deletions
+33
-19
consistent_hashing_load_balancer.cpp
src/brpc/policy/consistent_hashing_load_balancer.cpp
+1
-2
randomized_load_balancer.cpp
src/brpc/policy/randomized_load_balancer.cpp
+1
-2
round_robin_load_balancer.cpp
src/brpc/policy/round_robin_load_balancer.cpp
+1
-2
weighted_round_robin_load_balancer.cpp
src/brpc/policy/weighted_round_robin_load_balancer.cpp
+1
-2
revive_policy.cpp
src/brpc/revive_policy.cpp
+8
-2
revive_policy.h
src/brpc/revive_policy.h
+3
-2
brpc_load_balancer_unittest.cpp
test/brpc_load_balancer_unittest.cpp
+18
-7
No files found.
src/brpc/policy/consistent_hashing_load_balancer.cpp
View file @
b17bcc8b
...
@@ -303,7 +303,7 @@ int ConsistentHashingLoadBalancer::SelectServer(
...
@@ -303,7 +303,7 @@ int ConsistentHashingLoadBalancer::SelectServer(
return
ENODATA
;
return
ENODATA
;
}
}
RevivePolicy
*
rp
=
in
.
revive_policy
;
RevivePolicy
*
rp
=
in
.
revive_policy
;
if
(
rp
)
{
if
(
rp
&&
rp
->
StopRevivingIfNecessary
()
)
{
std
::
set
<
ServerId
>
server_list
;
std
::
set
<
ServerId
>
server_list
;
for
(
auto
server
:
*
s
)
{
for
(
auto
server
:
*
s
)
{
server_list
.
insert
(
server
.
server_sock
);
server_list
.
insert
(
server
.
server_sock
);
...
@@ -313,7 +313,6 @@ int ConsistentHashingLoadBalancer::SelectServer(
...
@@ -313,7 +313,6 @@ int ConsistentHashingLoadBalancer::SelectServer(
if
(
rp
->
DoReject
(
server_list_distinct
))
{
if
(
rp
->
DoReject
(
server_list_distinct
))
{
return
EREJECT
;
return
EREJECT
;
}
}
rp
->
StopRevivingIfNecessary
();
}
}
std
::
vector
<
Node
>::
const_iterator
choice
=
std
::
vector
<
Node
>::
const_iterator
choice
=
...
...
src/brpc/policy/randomized_load_balancer.cpp
View file @
b17bcc8b
...
@@ -111,11 +111,10 @@ int RandomizedLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
...
@@ -111,11 +111,10 @@ int RandomizedLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
return
ENODATA
;
return
ENODATA
;
}
}
RevivePolicy
*
rp
=
in
.
revive_policy
;
RevivePolicy
*
rp
=
in
.
revive_policy
;
if
(
rp
)
{
if
(
rp
&&
rp
->
StopRevivingIfNecessary
()
)
{
if
(
rp
->
DoReject
(
s
->
server_list
))
{
if
(
rp
->
DoReject
(
s
->
server_list
))
{
return
EREJECT
;
return
EREJECT
;
}
}
rp
->
StopRevivingIfNecessary
();
}
}
uint32_t
stride
=
0
;
uint32_t
stride
=
0
;
size_t
offset
=
butil
::
fast_rand_less_than
(
n
);
size_t
offset
=
butil
::
fast_rand_less_than
(
n
);
...
...
src/brpc/policy/round_robin_load_balancer.cpp
View file @
b17bcc8b
...
@@ -111,11 +111,10 @@ int RoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
...
@@ -111,11 +111,10 @@ int RoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut* out) {
return
ENODATA
;
return
ENODATA
;
}
}
RevivePolicy
*
rp
=
in
.
revive_policy
;
RevivePolicy
*
rp
=
in
.
revive_policy
;
if
(
rp
)
{
if
(
rp
&&
rp
->
StopRevivingIfNecessary
()
)
{
if
(
rp
->
DoReject
(
s
->
server_list
))
{
if
(
rp
->
DoReject
(
s
->
server_list
))
{
return
EREJECT
;
return
EREJECT
;
}
}
rp
->
StopRevivingIfNecessary
();
}
}
TLS
tls
=
s
.
tls
();
TLS
tls
=
s
.
tls
();
if
(
tls
.
stride
==
0
)
{
if
(
tls
.
stride
==
0
)
{
...
...
src/brpc/policy/weighted_round_robin_load_balancer.cpp
View file @
b17bcc8b
...
@@ -159,7 +159,7 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
...
@@ -159,7 +159,7 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
return
ENODATA
;
return
ENODATA
;
}
}
RevivePolicy
*
rp
=
in
.
revive_policy
;
RevivePolicy
*
rp
=
in
.
revive_policy
;
if
(
rp
)
{
if
(
rp
&&
rp
->
StopRevivingIfNecessary
()
)
{
std
::
vector
<
ServerId
>
server_list
;
std
::
vector
<
ServerId
>
server_list
;
server_list
.
reserve
(
s
->
server_list
.
size
());
server_list
.
reserve
(
s
->
server_list
.
size
());
for
(
auto
server
:
s
->
server_list
)
{
for
(
auto
server
:
s
->
server_list
)
{
...
@@ -168,7 +168,6 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
...
@@ -168,7 +168,6 @@ int WeightedRoundRobinLoadBalancer::SelectServer(const SelectIn& in, SelectOut*
if
(
rp
->
DoReject
(
server_list
))
{
if
(
rp
->
DoReject
(
server_list
))
{
return
EREJECT
;
return
EREJECT
;
}
}
rp
->
StopRevivingIfNecessary
();
}
}
TLS
&
tls
=
s
.
tls
();
TLS
&
tls
=
s
.
tls
();
if
(
tls
.
IsNeededCaculateNewStride
(
s
->
weight_sum
,
s
->
server_list
.
size
()))
{
if
(
tls
.
IsNeededCaculateNewStride
(
s
->
weight_sum
,
s
->
server_list
.
size
()))
{
...
...
src/brpc/revive_policy.cpp
View file @
b17bcc8b
...
@@ -39,17 +39,23 @@ void DefaultRevivePolicy::StartReviving() {
...
@@ -39,17 +39,23 @@ void DefaultRevivePolicy::StartReviving() {
_reviving
=
true
;
_reviving
=
true
;
}
}
void
DefaultRevivePolicy
::
StopRevivingIfNecessary
()
{
bool
DefaultRevivePolicy
::
StopRevivingIfNecessary
()
{
int64_t
now_ms
=
butil
::
gettimeofday_ms
();
int64_t
now_ms
=
butil
::
gettimeofday_ms
();
{
{
std
::
unique_lock
<
butil
::
Mutex
>
mu
(
_mutex
);
std
::
unique_lock
<
butil
::
Mutex
>
mu
(
_mutex
);
if
(
!
_reviving
)
{
mu
.
unlock
();
return
false
;
}
if
(
_last_usable_change_time_ms
!=
0
&&
_last_usable
!=
0
&&
if
(
_last_usable_change_time_ms
!=
0
&&
_last_usable
!=
0
&&
(
now_ms
-
_last_usable_change_time_ms
>
_hold_time_ms
))
{
(
now_ms
-
_last_usable_change_time_ms
>
_hold_time_ms
))
{
_reviving
=
false
;
_reviving
=
false
;
_last_usable_change_time_ms
=
0
;
_last_usable_change_time_ms
=
0
;
mu
.
unlock
();
return
false
;
}
}
}
}
return
;
return
true
;
}
}
bool
DefaultRevivePolicy
::
DoReject
(
const
std
::
vector
<
ServerId
>&
server_list
)
{
bool
DefaultRevivePolicy
::
DoReject
(
const
std
::
vector
<
ServerId
>&
server_list
)
{
...
...
src/brpc/revive_policy.h
View file @
b17bcc8b
...
@@ -41,7 +41,8 @@ public:
...
@@ -41,7 +41,8 @@ public:
// Stop reviving state and do not reject the request if some condition is
// Stop reviving state and do not reject the request if some condition is
// satisfied.
// satisfied.
virtual
void
StopRevivingIfNecessary
()
=
0
;
// Return true if the current state is still in reviving.
virtual
bool
StopRevivingIfNecessary
()
=
0
;
};
};
// The default revive policy. Once no servers are available, reviving is start.
// The default revive policy. Once no servers are available, reviving is start.
...
@@ -56,7 +57,7 @@ public:
...
@@ -56,7 +57,7 @@ public:
void
StartReviving
();
void
StartReviving
();
bool
DoReject
(
const
std
::
vector
<
ServerId
>&
server_list
);
bool
DoReject
(
const
std
::
vector
<
ServerId
>&
server_list
);
void
StopRevivingIfNecessary
();
bool
StopRevivingIfNecessary
();
private
:
private
:
bool
_reviving
;
bool
_reviving
;
...
...
test/brpc_load_balancer_unittest.cpp
View file @
b17bcc8b
...
@@ -789,7 +789,18 @@ TEST_F(LoadBalancerTest, health_check_no_valid_server) {
...
@@ -789,7 +789,18 @@ TEST_F(LoadBalancerTest, health_check_no_valid_server) {
}
}
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_sanity
)
{
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_sanity
)
{
brpc
::
LoadBalancer
*
lb
=
new
brpc
::
policy
::
RandomizedLoadBalancer
;
brpc
::
LoadBalancer
*
lb
=
NULL
;
int
rand
=
butil
::
fast_rand_less_than
(
4
);
if
(
rand
==
0
)
{
lb
=
new
brpc
::
policy
::
RoundRobinLoadBalancer
;
}
else
if
(
rand
==
1
)
{
lb
=
new
brpc
::
policy
::
RandomizedLoadBalancer
;
}
else
if
(
rand
==
2
)
{
lb
=
new
brpc
::
policy
::
WeightedRoundRobinLoadBalancer
;
}
else
{
lb
=
new
brpc
::
policy
::
ConsistentHashingLoadBalancer
(
brpc
::
policy
::
MurmurHash32
);
}
LOG
(
INFO
)
<<
"r="
<<
rand
;
brpc
::
SocketUniquePtr
ptr
[
2
];
brpc
::
SocketUniquePtr
ptr
[
2
];
for
(
size_t
i
=
0
;
i
<
ARRAY_SIZE
(
servers
);
++
i
)
{
for
(
size_t
i
=
0
;
i
<
ARRAY_SIZE
(
servers
);
++
i
)
{
butil
::
EndPoint
dummy
;
butil
::
EndPoint
dummy
;
...
@@ -797,12 +808,15 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_sanity) {
...
@@ -797,12 +808,15 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_sanity) {
brpc
::
SocketOptions
options
;
brpc
::
SocketOptions
options
;
options
.
remote_side
=
dummy
;
options
.
remote_side
=
dummy
;
brpc
::
ServerId
id
(
8888
);
brpc
::
ServerId
id
(
8888
);
id
.
tag
=
"50"
;
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Create
(
options
,
&
id
.
id
));
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Create
(
options
,
&
id
.
id
));
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
id
.
id
,
&
ptr
[
i
]));
ASSERT_EQ
(
0
,
brpc
::
Socket
::
Address
(
id
.
id
,
&
ptr
[
i
]));
lb
->
AddServer
(
id
);
lb
->
AddServer
(
id
);
}
}
brpc
::
SocketUniquePtr
sptr
;
brpc
::
SocketUniquePtr
sptr
;
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
false
,
0u
,
NULL
,
NULL
};
int64_t
hold_time_ms
=
2000
;
brpc
::
RevivePolicy
*
rp
=
new
brpc
::
DefaultRevivePolicy
(
2
,
hold_time_ms
);
brpc
::
LoadBalancer
::
SelectIn
in
=
{
0
,
false
,
true
,
0u
,
NULL
,
rp
};
brpc
::
LoadBalancer
::
SelectOut
out
(
&
sptr
);
brpc
::
LoadBalancer
::
SelectOut
out
(
&
sptr
);
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
ASSERT_EQ
(
0
,
lb
->
SelectServer
(
in
,
&
out
));
...
@@ -831,10 +845,8 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_sanity) {
...
@@ -831,10 +845,8 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_sanity) {
ASSERT_TRUE
(
false
);
ASSERT_TRUE
(
false
);
}
}
}
}
ASSERT_TRUE
(
abs
(
num_ereject
-
num_ok
)
<
20
);
ASSERT_TRUE
(
abs
(
num_ereject
-
num_ok
)
<
30
);
// TODO(zhujiashun): longer than interval
bthread_usleep
((
hold_time_ms
+
10
)
*
1000
);
int64_t
sleep_time_ms
=
2010
;
bthread_usleep
(
sleep_time_ms
*
1000
);
// After enough waiting time, traffic should be sent to all available servers.
// After enough waiting time, traffic should be sent to all available servers.
for
(
int
i
=
0
;
i
<
10
;
++
i
)
{
for
(
int
i
=
0
;
i
<
10
;
++
i
)
{
...
@@ -932,7 +944,6 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -932,7 +944,6 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
cntl
.
set_request_code
(
brpc
::
policy
::
MurmurHash32
(
&++
request_code
,
8
));
cntl
.
set_request_code
(
brpc
::
policy
::
MurmurHash32
(
&++
request_code
,
8
));
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
}
}
bthread_usleep
(
500000
);
butil
::
EndPoint
point
(
butil
::
IP_ANY
,
7777
);
butil
::
EndPoint
point
(
butil
::
IP_ANY
,
7777
);
brpc
::
Server
server
;
brpc
::
Server
server
;
...
...
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