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
ea5151d3
Commit
ea5151d3
authored
Aug 01, 2018
by
TousakaRin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rename class: GradientConcurrencyLimiter to AutoConcurrencyLimiter
parent
f7daa9b7
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
47 additions
and
48 deletions
+47
-48
global.cpp
src/brpc/global.cpp
+3
-4
auto_concurrency_limiter.cpp
src/brpc/policy/auto_concurrency_limiter.cpp
+37
-37
auto_concurrency_limiter.h
src/brpc/policy/auto_concurrency_limiter.h
+7
-7
No files found.
src/brpc/global.cpp
View file @
ea5151d3
...
@@ -67,7 +67,7 @@
...
@@ -67,7 +67,7 @@
// Concurrency Limiters
// Concurrency Limiters
#include "brpc/concurrency_limiter.h"
#include "brpc/concurrency_limiter.h"
#include "brpc/policy/
gradient
_concurrency_limiter.h"
#include "brpc/policy/
auto
_concurrency_limiter.h"
#include "brpc/policy/constant_concurrency_limiter.h"
#include "brpc/policy/constant_concurrency_limiter.h"
#include "brpc/input_messenger.h" // get_or_new_client_side_messenger
#include "brpc/input_messenger.h" // get_or_new_client_side_messenger
...
@@ -125,7 +125,7 @@ struct GlobalExtensions {
...
@@ -125,7 +125,7 @@ struct GlobalExtensions {
ConsistentHashingLoadBalancer
ch_md5_lb
;
ConsistentHashingLoadBalancer
ch_md5_lb
;
DynPartLoadBalancer
dynpart_lb
;
DynPartLoadBalancer
dynpart_lb
;
GradientConcurrencyLimiter
gradient
_cl
;
AutoConcurrencyLimiter
auto
_cl
;
ConstantConcurrencyLimiter
constant_cl
;
ConstantConcurrencyLimiter
constant_cl
;
};
};
...
@@ -558,8 +558,7 @@ static void GlobalInitializeOrDieImpl() {
...
@@ -558,8 +558,7 @@ static void GlobalInitializeOrDieImpl() {
}
}
// Concurrency Limiters
// Concurrency Limiters
ConcurrencyLimiterExtension
()
->
RegisterOrDie
(
"auto"
,
&
g_ext
->
gradient_cl
);
ConcurrencyLimiterExtension
()
->
RegisterOrDie
(
"auto"
,
&
g_ext
->
auto_cl
);
ConcurrencyLimiterExtension
()
->
RegisterOrDie
(
"gradient"
,
&
g_ext
->
gradient_cl
);
ConcurrencyLimiterExtension
()
->
RegisterOrDie
(
"constant"
,
&
g_ext
->
constant_cl
);
ConcurrencyLimiterExtension
()
->
RegisterOrDie
(
"constant"
,
&
g_ext
->
constant_cl
);
if
(
FLAGS_usercode_in_pthread
)
{
if
(
FLAGS_usercode_in_pthread
)
{
...
...
src/brpc/policy/
gradient
_concurrency_limiter.cpp
→
src/brpc/policy/
auto
_concurrency_limiter.cpp
View file @
ea5151d3
...
@@ -17,71 +17,71 @@
...
@@ -17,71 +17,71 @@
#include <cmath>
#include <cmath>
#include <gflags/gflags.h>
#include <gflags/gflags.h>
#include "brpc/errno.pb.h"
#include "brpc/errno.pb.h"
#include "brpc/policy/
gradient
_concurrency_limiter.h"
#include "brpc/policy/
auto
_concurrency_limiter.h"
namespace
brpc
{
namespace
brpc
{
namespace
policy
{
namespace
policy
{
DEFINE_int32
(
gradient
_cl_peak_qps_window_size
,
30
,
""
);
DEFINE_int32
(
auto
_cl_peak_qps_window_size
,
30
,
""
);
DEFINE_int32
(
gradient
_cl_sampling_interval_us
,
100
,
DEFINE_int32
(
auto
_cl_sampling_interval_us
,
100
,
"Interval for sampling request in
gradient
concurrency limiter"
);
"Interval for sampling request in
auto
concurrency limiter"
);
DEFINE_int32
(
gradient
_cl_sample_window_size_ms
,
1000
,
DEFINE_int32
(
auto
_cl_sample_window_size_ms
,
1000
,
"Sample window size for update max concurrency in grandient "
"Sample window size for update max concurrency in grandient "
"concurrency limiter"
);
"concurrency limiter"
);
DEFINE_int32
(
gradient
_cl_min_sample_count
,
100
,
DEFINE_int32
(
auto
_cl_min_sample_count
,
100
,
"Minimum sample count for update max concurrency"
);
"Minimum sample count for update max concurrency"
);
DEFINE_double
(
gradient
_cl_adjust_smooth
,
0.9
,
DEFINE_double
(
auto
_cl_adjust_smooth
,
0.9
,
"Smooth coefficient for adjust the max concurrency, the value is 0-1,"
"Smooth coefficient for adjust the max concurrency, the value is 0-1,"
"the larger the value, the smaller the amount of each change"
);
"the larger the value, the smaller the amount of each change"
);
DEFINE_int32
(
gradient
_cl_initial_max_concurrency
,
40
,
DEFINE_int32
(
auto
_cl_initial_max_concurrency
,
40
,
"Initial max concurrency for grandient concurrency limiter"
);
"Initial max concurrency for grandient concurrency limiter"
);
DEFINE_bool
(
gradient
_cl_enable_error_punish
,
true
,
DEFINE_bool
(
auto
_cl_enable_error_punish
,
true
,
"Whether to consider failed requests when calculating maximum concurrency"
);
"Whether to consider failed requests when calculating maximum concurrency"
);
DEFINE_double
(
gradient
_cl_fail_punish_ratio
,
1.0
,
DEFINE_double
(
auto
_cl_fail_punish_ratio
,
1.0
,
"Use the failed requests to punish normal requests. The larger the "
"Use the failed requests to punish normal requests. The larger the "
"configuration item, the more aggressive the penalty strategy."
);
"configuration item, the more aggressive the penalty strategy."
);
DEFINE_int32
(
gradient
_cl_reserved_concurrency
,
0
,
DEFINE_int32
(
auto
_cl_reserved_concurrency
,
0
,
"The maximum concurrency reserved when the service is not overloaded."
"The maximum concurrency reserved when the service is not overloaded."
"When the traffic increases, the larger the configuration item, the "
"When the traffic increases, the larger the configuration item, the "
"faster the maximum concurrency grows until the server is fully loaded."
"faster the maximum concurrency grows until the server is fully loaded."
"When the value is less than or equal to 0, square root of current "
"When the value is less than or equal to 0, square root of current "
"concurrency is used."
);
"concurrency is used."
);
DEFINE_int32
(
gradient
_cl_reset_count
,
30
,
DEFINE_int32
(
auto
_cl_reset_count
,
30
,
"The service's latency will be re-measured every `reset_count' windows."
);
"The service's latency will be re-measured every `reset_count' windows."
);
static
int32_t
cast_max_concurrency
(
void
*
arg
)
{
static
int32_t
cast_max_concurrency
(
void
*
arg
)
{
return
*
(
int32_t
*
)
arg
;
return
*
(
int32_t
*
)
arg
;
}
}
GradientConcurrencyLimiter
::
Gradient
ConcurrencyLimiter
()
AutoConcurrencyLimiter
::
Auto
ConcurrencyLimiter
()
:
_reset_count
(
NextResetCount
())
:
_reset_count
(
NextResetCount
())
,
_min_latency_us
(
-
1
)
,
_min_latency_us
(
-
1
)
,
_smooth
(
FLAGS_
gradient
_cl_adjust_smooth
)
,
_smooth
(
FLAGS_
auto
_cl_adjust_smooth
)
,
_ema_peak_qps
(
-
1
)
,
_ema_peak_qps
(
-
1
)
,
_qps_bq
(
FLAGS_
gradient
_cl_peak_qps_window_size
)
,
_qps_bq
(
FLAGS_
auto
_cl_peak_qps_window_size
)
,
_max_concurrency_bvar
(
cast_max_concurrency
,
&
_max_concurrency
)
,
_max_concurrency_bvar
(
cast_max_concurrency
,
&
_max_concurrency
)
,
_last_sampling_time_us
(
0
)
,
_last_sampling_time_us
(
0
)
,
_total_succ_req
(
0
)
,
_total_succ_req
(
0
)
,
_current_concurrency
(
0
)
{
,
_current_concurrency
(
0
)
{
_max_concurrency
=
FLAGS_
gradient
_cl_initial_max_concurrency
;
_max_concurrency
=
FLAGS_
auto
_cl_initial_max_concurrency
;
}
}
int
Gradient
ConcurrencyLimiter
::
Expose
(
const
butil
::
StringPiece
&
prefix
)
{
int
Auto
ConcurrencyLimiter
::
Expose
(
const
butil
::
StringPiece
&
prefix
)
{
if
(
_max_concurrency_bvar
.
expose_as
(
prefix
,
"
gradient
_cl_max_concurrency"
)
!=
0
)
{
if
(
_max_concurrency_bvar
.
expose_as
(
prefix
,
"
auto
_cl_max_concurrency"
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
return
0
;
return
0
;
}
}
GradientConcurrencyLimiter
*
Gradient
ConcurrencyLimiter
::
New
()
const
{
AutoConcurrencyLimiter
*
Auto
ConcurrencyLimiter
::
New
()
const
{
return
new
(
std
::
nothrow
)
Gradient
ConcurrencyLimiter
;
return
new
(
std
::
nothrow
)
Auto
ConcurrencyLimiter
;
}
}
void
Gradient
ConcurrencyLimiter
::
Destroy
()
{
void
Auto
ConcurrencyLimiter
::
Destroy
()
{
delete
this
;
delete
this
;
}
}
bool
Gradient
ConcurrencyLimiter
::
OnRequested
()
{
bool
Auto
ConcurrencyLimiter
::
OnRequested
()
{
const
int32_t
current_concurrency
=
const
int32_t
current_concurrency
=
_current_concurrency
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
_current_concurrency
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
if
(
current_concurrency
>=
_max_concurrency
)
{
if
(
current_concurrency
>=
_max_concurrency
)
{
...
@@ -90,7 +90,7 @@ bool GradientConcurrencyLimiter::OnRequested() {
...
@@ -90,7 +90,7 @@ bool GradientConcurrencyLimiter::OnRequested() {
return
true
;
return
true
;
}
}
void
Gradient
ConcurrencyLimiter
::
OnResponded
(
int
error_code
,
int64_t
latency_us
)
{
void
Auto
ConcurrencyLimiter
::
OnResponded
(
int
error_code
,
int64_t
latency_us
)
{
_current_concurrency
.
fetch_sub
(
1
,
butil
::
memory_order_relaxed
);
_current_concurrency
.
fetch_sub
(
1
,
butil
::
memory_order_relaxed
);
if
(
0
==
error_code
)
{
if
(
0
==
error_code
)
{
_total_succ_req
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
_total_succ_req
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
...
@@ -104,7 +104,7 @@ void GradientConcurrencyLimiter::OnResponded(int error_code, int64_t latency_us)
...
@@ -104,7 +104,7 @@ void GradientConcurrencyLimiter::OnResponded(int error_code, int64_t latency_us)
if
(
last_sampling_time_us
==
0
||
if
(
last_sampling_time_us
==
0
||
now_time_us
-
last_sampling_time_us
>=
now_time_us
-
last_sampling_time_us
>=
FLAGS_
gradient
_cl_sampling_interval_us
)
{
FLAGS_
auto
_cl_sampling_interval_us
)
{
bool
sample_this_call
=
_last_sampling_time_us
.
compare_exchange_weak
(
bool
sample_this_call
=
_last_sampling_time_us
.
compare_exchange_weak
(
last_sampling_time_us
,
now_time_us
,
last_sampling_time_us
,
now_time_us
,
butil
::
memory_order_relaxed
);
butil
::
memory_order_relaxed
);
...
@@ -112,19 +112,19 @@ void GradientConcurrencyLimiter::OnResponded(int error_code, int64_t latency_us)
...
@@ -112,19 +112,19 @@ void GradientConcurrencyLimiter::OnResponded(int error_code, int64_t latency_us)
int32_t
max_concurrency
=
AddSample
(
error_code
,
latency_us
,
now_time_us
);
int32_t
max_concurrency
=
AddSample
(
error_code
,
latency_us
,
now_time_us
);
if
(
max_concurrency
!=
0
)
{
if
(
max_concurrency
!=
0
)
{
LOG
(
INFO
)
LOG
(
INFO
)
<<
"MaxConcurrency updated by
gradient
limiter:"
<<
"MaxConcurrency updated by
auto
limiter:"
<<
"current_max_concurrency:"
<<
max_concurrency
;
<<
"current_max_concurrency:"
<<
max_concurrency
;
}
}
}
}
}
}
}
}
int
Gradient
ConcurrencyLimiter
::
NextResetCount
()
{
int
Auto
ConcurrencyLimiter
::
NextResetCount
()
{
int
max_reset_count
=
FLAGS_
gradient
_cl_reset_count
;
int
max_reset_count
=
FLAGS_
auto
_cl_reset_count
;
return
butil
::
fast_rand_less_than
(
max_reset_count
/
2
)
+
max_reset_count
/
2
;
return
butil
::
fast_rand_less_than
(
max_reset_count
/
2
)
+
max_reset_count
/
2
;
}
}
int32_t
Gradient
ConcurrencyLimiter
::
AddSample
(
int
error_code
,
int32_t
Auto
ConcurrencyLimiter
::
AddSample
(
int
error_code
,
int64_t
latency_us
,
int64_t
latency_us
,
int64_t
sampling_time_us
)
{
int64_t
sampling_time_us
)
{
std
::
unique_lock
<
butil
::
Mutex
>
lock_guard
(
_sw_mutex
);
std
::
unique_lock
<
butil
::
Mutex
>
lock_guard
(
_sw_mutex
);
...
@@ -133,7 +133,7 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
...
@@ -133,7 +133,7 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
}
}
if
(
error_code
!=
0
&&
if
(
error_code
!=
0
&&
FLAGS_
gradient
_cl_enable_error_punish
)
{
FLAGS_
auto
_cl_enable_error_punish
)
{
++
_sw
.
failed_count
;
++
_sw
.
failed_count
;
_sw
.
total_failed_us
+=
latency_us
;
_sw
.
total_failed_us
+=
latency_us
;
}
else
if
(
error_code
==
0
)
{
}
else
if
(
error_code
==
0
)
{
...
@@ -142,9 +142,9 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
...
@@ -142,9 +142,9 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
}
}
if
(
sampling_time_us
-
_sw
.
start_time_us
<
if
(
sampling_time_us
-
_sw
.
start_time_us
<
FLAGS_
gradient
_cl_sample_window_size_ms
*
1000
||
FLAGS_
auto
_cl_sample_window_size_ms
*
1000
||
_sw
.
succ_count
+
_sw
.
failed_count
<
_sw
.
succ_count
+
_sw
.
failed_count
<
FLAGS_
gradient
_cl_min_sample_count
)
{
FLAGS_
auto
_cl_min_sample_count
)
{
return
0
;
return
0
;
}
}
...
@@ -162,7 +162,7 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
...
@@ -162,7 +162,7 @@ int32_t GradientConcurrencyLimiter::AddSample(int error_code,
}
}
}
}
void
Gradient
ConcurrencyLimiter
::
ResetSampleWindow
(
int64_t
sampling_time_us
)
{
void
Auto
ConcurrencyLimiter
::
ResetSampleWindow
(
int64_t
sampling_time_us
)
{
_sw
.
start_time_us
=
sampling_time_us
;
_sw
.
start_time_us
=
sampling_time_us
;
_sw
.
succ_count
=
0
;
_sw
.
succ_count
=
0
;
_sw
.
failed_count
=
0
;
_sw
.
failed_count
=
0
;
...
@@ -170,7 +170,7 @@ void GradientConcurrencyLimiter::ResetSampleWindow(int64_t sampling_time_us) {
...
@@ -170,7 +170,7 @@ void GradientConcurrencyLimiter::ResetSampleWindow(int64_t sampling_time_us) {
_sw
.
total_succ_us
=
0
;
_sw
.
total_succ_us
=
0
;
}
}
void
Gradient
ConcurrencyLimiter
::
UpdateMinLatency
(
int64_t
latency_us
)
{
void
Auto
ConcurrencyLimiter
::
UpdateMinLatency
(
int64_t
latency_us
)
{
if
(
_min_latency_us
<=
0
)
{
if
(
_min_latency_us
<=
0
)
{
_min_latency_us
=
latency_us
;
_min_latency_us
=
latency_us
;
}
else
if
(
latency_us
<
_min_latency_us
)
{
}
else
if
(
latency_us
<
_min_latency_us
)
{
...
@@ -178,7 +178,7 @@ void GradientConcurrencyLimiter::UpdateMinLatency(int64_t latency_us) {
...
@@ -178,7 +178,7 @@ void GradientConcurrencyLimiter::UpdateMinLatency(int64_t latency_us) {
}
}
}
}
void
Gradient
ConcurrencyLimiter
::
UpdateQps
(
int32_t
succ_count
,
void
Auto
ConcurrencyLimiter
::
UpdateQps
(
int32_t
succ_count
,
int64_t
sampling_time_us
)
{
int64_t
sampling_time_us
)
{
double
qps
=
1000000.0
*
succ_count
/
(
sampling_time_us
-
_sw
.
start_time_us
);
double
qps
=
1000000.0
*
succ_count
/
(
sampling_time_us
-
_sw
.
start_time_us
);
_qps_bq
.
elim_push
(
qps
);
_qps_bq
.
elim_push
(
qps
);
...
@@ -190,18 +190,18 @@ void GradientConcurrencyLimiter::UpdateQps(int32_t succ_count,
...
@@ -190,18 +190,18 @@ void GradientConcurrencyLimiter::UpdateQps(int32_t succ_count,
_ema_peak_qps
=
_ema_peak_qps
*
_smooth
+
peak_qps
*
(
1
-
_smooth
);
_ema_peak_qps
=
_ema_peak_qps
*
_smooth
+
peak_qps
*
(
1
-
_smooth
);
}
}
int32_t
Gradient
ConcurrencyLimiter
::
UpdateMaxConcurrency
(
int64_t
sampling_time_us
)
{
int32_t
Auto
ConcurrencyLimiter
::
UpdateMaxConcurrency
(
int64_t
sampling_time_us
)
{
int32_t
current_concurrency
=
_current_concurrency
.
load
();
int32_t
current_concurrency
=
_current_concurrency
.
load
();
int32_t
total_succ_req
=
int32_t
total_succ_req
=
_total_succ_req
.
exchange
(
0
,
butil
::
memory_order_relaxed
);
_total_succ_req
.
exchange
(
0
,
butil
::
memory_order_relaxed
);
double
failed_punish
=
double
failed_punish
=
_sw
.
total_failed_us
*
FLAGS_
gradient
_cl_fail_punish_ratio
;
_sw
.
total_failed_us
*
FLAGS_
auto
_cl_fail_punish_ratio
;
int64_t
avg_latency
=
int64_t
avg_latency
=
std
::
ceil
((
failed_punish
+
_sw
.
total_succ_us
)
/
_sw
.
succ_count
);
std
::
ceil
((
failed_punish
+
_sw
.
total_succ_us
)
/
_sw
.
succ_count
);
UpdateMinLatency
(
avg_latency
);
UpdateMinLatency
(
avg_latency
);
UpdateQps
(
total_succ_req
,
sampling_time_us
);
UpdateQps
(
total_succ_req
,
sampling_time_us
);
int
reserved_concurrency
=
FLAGS_
gradient
_cl_reserved_concurrency
;
int
reserved_concurrency
=
FLAGS_
auto
_cl_reserved_concurrency
;
if
(
reserved_concurrency
<=
0
)
{
if
(
reserved_concurrency
<=
0
)
{
reserved_concurrency
=
std
::
ceil
(
std
::
sqrt
(
_max_concurrency
));
reserved_concurrency
=
std
::
ceil
(
std
::
sqrt
(
_max_concurrency
));
}
}
...
...
src/brpc/policy/
gradient
_concurrency_limiter.h
→
src/brpc/policy/
auto
_concurrency_limiter.h
View file @
ea5151d3
...
@@ -14,8 +14,8 @@
...
@@ -14,8 +14,8 @@
//
//
// Authors: Lei He (helei@qiyi.com)
// Authors: Lei He (helei@qiyi.com)
#ifndef BRPC_POLICY_
GRANDIENT
_CONCURRENCY_LIMITER_H
#ifndef BRPC_POLICY_
AUTO
_CONCURRENCY_LIMITER_H
#define BRPC_POLICY_
GRANDIENT
_CONCURRENCY_LIMITER_H
#define BRPC_POLICY_
AUTO
_CONCURRENCY_LIMITER_H
#include "bvar/bvar.h"
#include "bvar/bvar.h"
#include "butil/containers/bounded_queue.h"
#include "butil/containers/bounded_queue.h"
...
@@ -24,15 +24,15 @@
...
@@ -24,15 +24,15 @@
namespace
brpc
{
namespace
brpc
{
namespace
policy
{
namespace
policy
{
class
Gradient
ConcurrencyLimiter
:
public
ConcurrencyLimiter
{
class
Auto
ConcurrencyLimiter
:
public
ConcurrencyLimiter
{
public
:
public
:
Gradient
ConcurrencyLimiter
();
Auto
ConcurrencyLimiter
();
~
Gradient
ConcurrencyLimiter
()
{}
~
Auto
ConcurrencyLimiter
()
{}
bool
OnRequested
()
override
;
bool
OnRequested
()
override
;
void
OnResponded
(
int
error_code
,
int64_t
latency_us
)
override
;
void
OnResponded
(
int
error_code
,
int64_t
latency_us
)
override
;
int
Expose
(
const
butil
::
StringPiece
&
prefix
)
override
;
int
Expose
(
const
butil
::
StringPiece
&
prefix
)
override
;
Gradient
ConcurrencyLimiter
*
New
()
const
override
;
Auto
ConcurrencyLimiter
*
New
()
const
override
;
void
Destroy
()
override
;
void
Destroy
()
override
;
private
:
private
:
...
@@ -78,4 +78,4 @@ private:
...
@@ -78,4 +78,4 @@ private:
}
// namespace brpc
}
// namespace brpc
#endif // BRPC_POLICY_
GRANDIENT
_CONCURRENCY_LIMITER_H
#endif // BRPC_POLICY_
AUTO
_CONCURRENCY_LIMITER_H
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