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
662ff4a4
Commit
662ff4a4
authored
Apr 15, 2019
by
zhujiashun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
revived_from_all_failed: fix ut after rebasing latest master
parent
75f89a5a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
35 deletions
+25
-35
cluster_recover_policy.cpp
src/brpc/cluster_recover_policy.cpp
+1
-1
brpc_load_balancer_unittest.cpp
test/brpc_load_balancer_unittest.cpp
+24
-34
No files found.
src/brpc/cluster_recover_policy.cpp
View file @
662ff4a4
...
@@ -72,7 +72,7 @@ uint64_t DefaultClusterRecoverPolicy::GetUsableServerCount(
...
@@ -72,7 +72,7 @@ uint64_t DefaultClusterRecoverPolicy::GetUsableServerCount(
SocketUniquePtr
ptr
;
SocketUniquePtr
ptr
;
for
(
size_t
i
=
0
;
i
<
n
;
++
i
)
{
for
(
size_t
i
=
0
;
i
<
n
;
++
i
)
{
if
(
Socket
::
Address
(
server_list
[
i
].
id
,
&
ptr
)
==
0
if
(
Socket
::
Address
(
server_list
[
i
].
id
,
&
ptr
)
==
0
&&
!
ptr
->
IsLogOff
())
{
&&
ptr
->
IsAvailable
())
{
usable
++
;
usable
++
;
}
}
}
}
...
...
test/brpc_load_balancer_unittest.cpp
View file @
662ff4a4
...
@@ -789,6 +789,10 @@ TEST_F(LoadBalancerTest, health_check_no_valid_server) {
...
@@ -789,6 +789,10 @@ TEST_F(LoadBalancerTest, health_check_no_valid_server) {
}
}
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_sanity
)
{
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_sanity
)
{
const
char
*
servers
[]
=
{
"10.92.115.19:8832"
,
"10.42.122.201:8833"
,
};
brpc
::
LoadBalancer
*
lb
=
NULL
;
brpc
::
LoadBalancer
*
lb
=
NULL
;
int
rand
=
butil
::
fast_rand_less_than
(
2
);
int
rand
=
butil
::
fast_rand_less_than
(
2
);
if
(
rand
==
0
)
{
if
(
rand
==
0
)
{
...
@@ -878,34 +882,31 @@ public:
...
@@ -878,34 +882,31 @@ public:
butil
::
atomic
<
int
>
_num_request
;
butil
::
atomic
<
int
>
_num_request
;
};
};
butil
::
atomic
<
int32_t
>
num_failed
;
butil
::
atomic
<
int32_t
>
num_reject
;
class
Done
:
public
google
::
protobuf
::
Closure
{
class
Done
:
public
google
::
protobuf
::
Closure
{
public
:
public
:
Done
()
:
num_failed
(
NULL
)
,
num_reject
(
NULL
)
{}
void
Run
()
{
void
Run
()
{
if
(
cntl
.
Failed
())
{
if
(
cntl
.
Failed
())
{
if
(
num_failed
)
{
num_failed
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
num_failed
->
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
if
(
cntl
.
ErrorCode
()
==
brpc
::
EREJECT
)
{
}
num_reject
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
if
(
cntl
.
ErrorCode
()
==
brpc
::
EREJECT
&&
num_reject
)
{
num_reject
->
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
}
}
}
}
delete
this
;
delete
this
;
}
}
brpc
::
Controller
cntl
;
brpc
::
Controller
cntl
;
test
::
EchoRequest
req
;
test
::
EchoRequest
req
;
test
::
EchoResponse
res
;
test
::
EchoResponse
res
;
butil
::
atomic
<
int32_t
>*
num_failed
;
butil
::
atomic
<
int32_t
>*
num_reject
;
};
};
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_intergrated
)
{
TEST_F
(
LoadBalancerTest
,
revived_from_all_failed_intergrated
)
{
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_short_window_size"
,
"20"
);
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_short_window_size"
,
"20"
);
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_short_window_error_percent"
,
"30"
);
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_short_window_error_percent"
,
"30"
);
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_max_isolation_duration_ms"
,
"5000"
);
// Those two lines force the interval of first hc to 3s
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_max_isolation_duration_ms"
,
"3000"
);
GFLAGS_NS
::
SetCommandLineOption
(
"circuit_breaker_min_isolation_duration_ms"
,
"3000"
);
const
char
*
lb_algo
[]
=
{
"random:minimum_working_instances=2 hold_time_ms=2000"
,
const
char
*
lb_algo
[]
=
{
"random:minimum_working_instances=2 hold_time_ms=2000"
,
"rr:minimum_working_instances=2 hold_time_ms=2000"
};
"rr:minimum_working_instances=2 hold_time_ms=2000"
};
...
@@ -914,24 +915,15 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -914,24 +915,15 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
options
.
protocol
=
"http"
;
options
.
protocol
=
"http"
;
options
.
timeout_ms
=
300
;
options
.
timeout_ms
=
300
;
options
.
enable_circuit_breaker
=
true
;
options
.
enable_circuit_breaker
=
true
;
// Set max_retry to 0 so that the time of health check of different servers
// are not continuous.
options
.
max_retry
=
0
;
ASSERT_EQ
(
channel
.
Init
(
"list://127.0.0.1:7777 50, 127.0.0.1:7778 50"
,
ASSERT_EQ
(
channel
.
Init
(
"list://127.0.0.1:7777 50, 127.0.0.1:7778 50"
,
lb_algo
[
butil
::
fast_rand_less_than
(
ARRAY_SIZE
(
lb_algo
))],
lb_algo
[
butil
::
fast_rand_less_than
(
ARRAY_SIZE
(
lb_algo
))],
&
options
),
0
);
&
options
),
0
);
test
::
EchoRequest
req
;
test
::
EchoRequest
req
;
req
.
set_message
(
"123"
);
req
.
set_message
(
"123"
);
test
::
EchoResponse
res
;
test
::
EchoResponse
res
;
test
::
EchoService_Stub
stub
(
&
channel
);
test
::
EchoService_Stub
stub
(
&
channel
);
// trigger one server to health check
int64_t
start_ms
=
butil
::
gettimeofday_ms
();
{
// trigger to health check
brpc
::
Controller
cntl
;
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
}
bthread_usleep
(
500000
);
// trigger the other server to health check
{
{
brpc
::
Controller
cntl
;
brpc
::
Controller
cntl
;
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
...
@@ -949,30 +941,28 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -949,30 +941,28 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
ASSERT_EQ
(
0
,
server2
.
AddService
(
&
service2
,
brpc
::
SERVER_DOESNT_OWN_SERVICE
));
ASSERT_EQ
(
0
,
server2
.
AddService
(
&
service2
,
brpc
::
SERVER_DOESNT_OWN_SERVICE
));
ASSERT_EQ
(
0
,
server2
.
Start
(
point2
,
NULL
));
ASSERT_EQ
(
0
,
server2
.
Start
(
point2
,
NULL
));
int64_t
start_ms
=
butil
::
gettimeofday_ms
();
// keep sending for 2900ms(100ms less than hc interval) to make sure all requests
butil
::
atomic
<
int32_t
>
num_reject
(
0
);
// are sent during hc. Those requests should be all failed and error code should
int64_t
q
=
0
;
// be brpc::EREJECT.
while
((
butil
::
gettimeofday_ms
()
-
start_ms
)
<
while
((
butil
::
gettimeofday_ms
()
-
start_ms
)
<
2900
)
{
brpc
::
FLAGS_health_check_interval
*
1000
+
10
)
{
Done
*
done
=
new
Done
;
Done
*
done
=
new
Done
;
done
->
num_reject
=
&
num_reject
;
done
->
req
.
set_message
(
"123"
);
done
->
req
.
set_message
(
"123"
);
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
q
++
;
bthread_usleep
(
1000
);
bthread_usleep
(
1000
);
}
}
ASSERT_TRUE
(
num_reject
.
load
(
butil
::
memory_order_relaxed
)
>
1700
);
ASSERT_EQ
(
num_reject
.
load
(
butil
::
memory_order_relaxed
),
num_failed
.
load
(
butil
::
memory_order_relaxed
));
num_failed
.
store
(
0
,
butil
::
memory_order_relaxed
);
bthread_usleep
(
500000
);
// should recover now
// should recover now
butil
::
atomic
<
int32_t
>
num_failed
(
0
);
for
(
int
i
=
0
;
i
<
1000
;
++
i
)
{
for
(
int
i
=
0
;
i
<
1000
;
++
i
)
{
Done
*
done
=
new
Done
;
Done
*
done
=
new
Done
;
done
->
req
.
set_message
(
"123"
);
done
->
req
.
set_message
(
"123"
);
done
->
num_failed
=
&
num_failed
;
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
bthread_usleep
(
1000
);
bthread_usleep
(
1000
);
}
}
bthread_usleep
(
1050
*
1000
/* sleep longer than timeout of service
*/
);
bthread_usleep
(
500000
/* sleep longer than timeout of channel
*/
);
ASSERT_EQ
(
0
,
num_failed
.
load
(
butil
::
memory_order_relaxed
));
ASSERT_EQ
(
0
,
num_failed
.
load
(
butil
::
memory_order_relaxed
));
}
}
...
...
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