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
47cd1eff
Commit
47cd1eff
authored
Jan 22, 2018
by
gejun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make percentiles on 50,90,99 configurable and change 50 to 80 by default
parent
686201a0
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
61 additions
and
23 deletions
+61
-23
series.h
src/bvar/detail/series.h
+1
-1
latency_recorder.cpp
src/bvar/latency_recorder.cpp
+53
-15
latency_recorder.h
src/bvar/latency_recorder.h
+4
-4
bvar_variable_unittest.cpp
test/bvar_variable_unittest.cpp
+3
-3
No files found.
src/bvar/detail/series.h
View file @
47cd1eff
...
@@ -41,7 +41,7 @@ struct ProbablyAddtition {
...
@@ -41,7 +41,7 @@ struct ProbablyAddtition {
ProbablyAddtition
(
const
Op
&
op
)
{
ProbablyAddtition
(
const
Op
&
op
)
{
T
res
(
32
);
T
res
(
32
);
call_op_returning_void
(
op
,
res
,
T
(
64
));
call_op_returning_void
(
op
,
res
,
T
(
64
));
_ok
=
(
res
==
96
);
// works for integral/floating point.
_ok
=
(
res
==
T
(
96
)
);
// works for integral/floating point.
}
}
operator
bool
()
const
{
return
_ok
;
}
operator
bool
()
const
{
return
_ok
;
}
private
:
private
:
...
...
src/bvar/latency_recorder.cpp
View file @
47cd1eff
...
@@ -15,10 +15,28 @@
...
@@ -15,10 +15,28 @@
// Author: Ge,Jun (gejun@baidu.com)
// Author: Ge,Jun (gejun@baidu.com)
// Date: 2014/09/22 11:57:43
// Date: 2014/09/22 11:57:43
#include
"bvar/latency_recorder.h"
#include
<gflags/gflags.h>
#include "butil/unique_ptr.h"
#include "butil/unique_ptr.h"
#include "bvar/latency_recorder.h"
namespace
bvar
{
namespace
bvar
{
// Reloading following gflags does not change names of the corresponding bvars.
// Avoid reloading in practice.
DEFINE_int32
(
bvar_latency_p1
,
80
,
"First latency percentile"
);
DEFINE_int32
(
bvar_latency_p2
,
90
,
"Second latency percentile"
);
DEFINE_int32
(
bvar_latency_p3
,
99
,
"Third latency percentile"
);
static
bool
valid_percentile
(
const
char
*
,
int32_t
v
)
{
return
v
>
0
&&
v
<
100
;
}
const
bool
ALLOW_UNUSED
dummy_bvar_latency_p1
=
::
google
::
RegisterFlagValidator
(
&
FLAGS_bvar_latency_p1
,
valid_percentile
);
const
bool
ALLOW_UNUSED
dummy_bvar_latency_p2
=
::
google
::
RegisterFlagValidator
(
&
FLAGS_bvar_latency_p2
,
valid_percentile
);
const
bool
ALLOW_UNUSED
dummy_bvar_latency_p3
=
::
google
::
RegisterFlagValidator
(
&
FLAGS_bvar_latency_p3
,
valid_percentile
);
namespace
detail
{
namespace
detail
{
typedef
PercentileSamples
<
1022
>
CombinedPercentileSamples
;
typedef
PercentileSamples
<
1022
>
CombinedPercentileSamples
;
...
@@ -93,11 +111,24 @@ static CombinedPercentileSamples* combine(PercentileWindow* w) {
...
@@ -93,11 +111,24 @@ static CombinedPercentileSamples* combine(PercentileWindow* w) {
}
}
template
<
int64_t
numerator
,
int64_t
denominator
>
template
<
int64_t
numerator
,
int64_t
denominator
>
int64_t
get_percetile
(
void
*
arg
)
{
static
int64_t
get_percetile
(
void
*
arg
)
{
return
((
LatencyRecorder
*
)
arg
)
->
latency_percentile
(
return
((
LatencyRecorder
*
)
arg
)
->
latency_percentile
(
(
double
)
numerator
/
double
(
denominator
));
(
double
)
numerator
/
double
(
denominator
));
}
}
static
int64_t
get_p1
(
void
*
arg
)
{
LatencyRecorder
*
lr
=
static_cast
<
LatencyRecorder
*>
(
arg
);
return
lr
->
latency_percentile
(
FLAGS_bvar_latency_p1
/
100.0
);
}
static
int64_t
get_p2
(
void
*
arg
)
{
LatencyRecorder
*
lr
=
static_cast
<
LatencyRecorder
*>
(
arg
);
return
lr
->
latency_percentile
(
FLAGS_bvar_latency_p2
/
100.0
);
}
static
int64_t
get_p3
(
void
*
arg
)
{
LatencyRecorder
*
lr
=
static_cast
<
LatencyRecorder
*>
(
arg
);
return
lr
->
latency_percentile
(
FLAGS_bvar_latency_p3
/
100.0
);
}
static
Vector
<
int64_t
,
4
>
get_latencies
(
void
*
arg
)
{
static
Vector
<
int64_t
,
4
>
get_latencies
(
void
*
arg
)
{
std
::
unique_ptr
<
CombinedPercentileSamples
>
cb
(
std
::
unique_ptr
<
CombinedPercentileSamples
>
cb
(
combine
((
PercentileWindow
*
)
arg
));
combine
((
PercentileWindow
*
)
arg
));
...
@@ -105,9 +136,9 @@ static Vector<int64_t, 4> get_latencies(void *arg) {
...
@@ -105,9 +136,9 @@ static Vector<int64_t, 4> get_latencies(void *arg) {
// other values and make other curves on the plotted graph small and
// other values and make other curves on the plotted graph small and
// hard to read.
// hard to read.
Vector
<
int64_t
,
4
>
result
;
Vector
<
int64_t
,
4
>
result
;
result
[
0
]
=
cb
->
get_number
(
0.5
);
result
[
0
]
=
cb
->
get_number
(
FLAGS_bvar_latency_p1
/
100.0
);
result
[
1
]
=
cb
->
get_number
(
0.9
0
);
result
[
1
]
=
cb
->
get_number
(
FLAGS_bvar_latency_p2
/
100.
0
);
result
[
2
]
=
cb
->
get_number
(
0.99
);
result
[
2
]
=
cb
->
get_number
(
FLAGS_bvar_latency_p3
/
100.0
);
result
[
3
]
=
cb
->
get_number
(
0.999
);
result
[
3
]
=
cb
->
get_number
(
0.999
);
return
result
;
return
result
;
}
}
...
@@ -119,9 +150,9 @@ LatencyRecorderBase::LatencyRecorderBase(time_t window_size)
...
@@ -119,9 +150,9 @@ LatencyRecorderBase::LatencyRecorderBase(time_t window_size)
,
_count
(
get_recorder_count
,
&
_latency
)
,
_count
(
get_recorder_count
,
&
_latency
)
,
_qps
(
get_window_recorder_qps
,
&
_latency_window
)
,
_qps
(
get_window_recorder_qps
,
&
_latency_window
)
,
_latency_percentile_window
(
&
_latency_percentile
,
window_size
)
,
_latency_percentile_window
(
&
_latency_percentile
,
window_size
)
,
_latency_
50
(
get_percetile
<
50
,
100
>
,
this
)
,
_latency_
p1
(
get_p1
,
this
)
,
_latency_
90
(
get_percetile
<
90
,
100
>
,
this
)
,
_latency_
p2
(
get_p2
,
this
)
,
_latency_
99
(
get_percetile
<
99
,
100
>
,
this
)
,
_latency_
p3
(
get_p3
,
this
)
,
_latency_999
(
get_percetile
<
999
,
1000
>
,
this
)
,
_latency_999
(
get_percetile
<
999
,
1000
>
,
this
)
,
_latency_9999
(
get_percetile
<
9999
,
10000
>
,
this
)
,
_latency_9999
(
get_percetile
<
9999
,
10000
>
,
this
)
,
_latency_cdf
(
&
_latency_percentile_window
)
,
_latency_cdf
(
&
_latency_percentile_window
)
...
@@ -186,13 +217,17 @@ int LatencyRecorder::expose(const butil::StringPiece& prefix1,
...
@@ -186,13 +217,17 @@ int LatencyRecorder::expose(const butil::StringPiece& prefix1,
if
(
_qps
.
expose_as
(
prefix
,
"qps"
)
!=
0
)
{
if
(
_qps
.
expose_as
(
prefix
,
"qps"
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
if
(
_latency_50
.
expose_as
(
prefix
,
"latency_50"
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
char
namebuf
[
32
];
snprintf
(
namebuf
,
sizeof
(
namebuf
),
"latency_%d"
,
(
int
)
FLAGS_bvar_latency_p1
);
if
(
_latency_p1
.
expose_as
(
prefix
,
namebuf
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
if
(
_latency_90
.
expose_as
(
prefix
,
"latency_90"
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
snprintf
(
namebuf
,
sizeof
(
namebuf
),
"latency_%d"
,
(
int
)
FLAGS_bvar_latency_p2
);
if
(
_latency_p2
.
expose_as
(
prefix
,
namebuf
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
if
(
_latency_99
.
expose_as
(
prefix
,
"latency_99"
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
snprintf
(
namebuf
,
sizeof
(
namebuf
),
"latency_%u"
,
(
int
)
FLAGS_bvar_latency_p3
);
if
(
_latency_p3
.
expose_as
(
prefix
,
namebuf
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
if
(
_latency_999
.
expose_as
(
prefix
,
"latency_999"
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
if
(
_latency_999
.
expose_as
(
prefix
,
"latency_999"
,
DISPLAY_ON_PLAIN_TEXT
)
!=
0
)
{
...
@@ -207,7 +242,10 @@ int LatencyRecorder::expose(const butil::StringPiece& prefix1,
...
@@ -207,7 +242,10 @@ int LatencyRecorder::expose(const butil::StringPiece& prefix1,
if
(
_latency_percentiles
.
expose_as
(
prefix
,
"latency_percentiles"
,
DISPLAY_ON_HTML
)
!=
0
)
{
if
(
_latency_percentiles
.
expose_as
(
prefix
,
"latency_percentiles"
,
DISPLAY_ON_HTML
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
CHECK_EQ
(
0
,
_latency_percentiles
.
set_vector_names
(
"50%,90%,99%,99.9%"
));
snprintf
(
namebuf
,
sizeof
(
namebuf
),
"%d%%,%d%%,%d%%,99.9%%"
,
(
int
)
FLAGS_bvar_latency_p1
,
(
int
)
FLAGS_bvar_latency_p2
,
(
int
)
FLAGS_bvar_latency_p3
);
CHECK_EQ
(
0
,
_latency_percentiles
.
set_vector_names
(
namebuf
));
return
0
;
return
0
;
}
}
...
@@ -222,9 +260,9 @@ void LatencyRecorder::hide() {
...
@@ -222,9 +260,9 @@ void LatencyRecorder::hide() {
_max_latency_window
.
hide
();
_max_latency_window
.
hide
();
_count
.
hide
();
_count
.
hide
();
_qps
.
hide
();
_qps
.
hide
();
_latency_
50
.
hide
();
_latency_
p1
.
hide
();
_latency_
90
.
hide
();
_latency_
p2
.
hide
();
_latency_
99
.
hide
();
_latency_
p3
.
hide
();
_latency_999
.
hide
();
_latency_999
.
hide
();
_latency_9999
.
hide
();
_latency_9999
.
hide
();
}
}
...
...
src/bvar/latency_recorder.h
View file @
47cd1eff
...
@@ -58,9 +58,9 @@ protected:
...
@@ -58,9 +58,9 @@ protected:
PassiveStatus
<
int64_t
>
_count
;
PassiveStatus
<
int64_t
>
_count
;
PassiveStatus
<
int64_t
>
_qps
;
PassiveStatus
<
int64_t
>
_qps
;
PercentileWindow
_latency_percentile_window
;
PercentileWindow
_latency_percentile_window
;
PassiveStatus
<
int64_t
>
_latency_
50
;
PassiveStatus
<
int64_t
>
_latency_
p1
;
PassiveStatus
<
int64_t
>
_latency_
90
;
PassiveStatus
<
int64_t
>
_latency_
p2
;
PassiveStatus
<
int64_t
>
_latency_
99
;
PassiveStatus
<
int64_t
>
_latency_
p3
;
PassiveStatus
<
int64_t
>
_latency_999
;
// 99.9%
PassiveStatus
<
int64_t
>
_latency_999
;
// 99.9%
PassiveStatus
<
int64_t
>
_latency_9999
;
// 99.99%
PassiveStatus
<
int64_t
>
_latency_9999
;
// 99.99%
CDF
_latency_cdf
;
CDF
_latency_cdf
;
...
@@ -125,7 +125,7 @@ public:
...
@@ -125,7 +125,7 @@ public:
int64_t
latency
()
const
int64_t
latency
()
const
{
return
_latency_window
.
get_value
().
get_average_int
();
}
{
return
_latency_window
.
get_value
().
get_average_int
();
}
// Get
50/90/99
/99.9-ile latencies in recent window_size-to-ctor seconds.
// Get
p1/p2/p3
/99.9-ile latencies in recent window_size-to-ctor seconds.
Vector
<
int64_t
,
4
>
latency_percentiles
()
const
;
Vector
<
int64_t
,
4
>
latency_percentiles
()
const
;
// Get the max latency in recent window_size-to-ctor seconds.
// Get the max latency in recent window_size-to-ctor seconds.
...
...
test/bvar_variable_unittest.cpp
View file @
47cd1eff
...
@@ -313,7 +313,7 @@ TEST_F(VariableTest, latency_recorder) {
...
@@ -313,7 +313,7 @@ TEST_F(VariableTest, latency_recorder) {
ASSERT_EQ
(
11UL
,
names
.
size
())
<<
vec2string
(
names
);
ASSERT_EQ
(
11UL
,
names
.
size
())
<<
vec2string
(
names
);
ASSERT_EQ
(
"foo_bar_count"
,
names
[
0
]);
ASSERT_EQ
(
"foo_bar_count"
,
names
[
0
]);
ASSERT_EQ
(
"foo_bar_latency"
,
names
[
1
]);
ASSERT_EQ
(
"foo_bar_latency"
,
names
[
1
]);
ASSERT_EQ
(
"foo_bar_latency_
5
0"
,
names
[
2
]);
ASSERT_EQ
(
"foo_bar_latency_
8
0"
,
names
[
2
]);
ASSERT_EQ
(
"foo_bar_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"foo_bar_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"foo_bar_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"foo_bar_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"foo_bar_latency_999"
,
names
[
5
]);
ASSERT_EQ
(
"foo_bar_latency_999"
,
names
[
5
]);
...
@@ -329,7 +329,7 @@ TEST_F(VariableTest, latency_recorder) {
...
@@ -329,7 +329,7 @@ TEST_F(VariableTest, latency_recorder) {
ASSERT_EQ
(
11UL
,
names
.
size
());
ASSERT_EQ
(
11UL
,
names
.
size
());
ASSERT_EQ
(
"apple_pie_count"
,
names
[
0
]);
ASSERT_EQ
(
"apple_pie_count"
,
names
[
0
]);
ASSERT_EQ
(
"apple_pie_latency"
,
names
[
1
]);
ASSERT_EQ
(
"apple_pie_latency"
,
names
[
1
]);
ASSERT_EQ
(
"apple_pie_latency_
5
0"
,
names
[
2
]);
ASSERT_EQ
(
"apple_pie_latency_
8
0"
,
names
[
2
]);
ASSERT_EQ
(
"apple_pie_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"apple_pie_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"apple_pie_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"apple_pie_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"apple_pie_latency_999"
,
names
[
5
]);
ASSERT_EQ
(
"apple_pie_latency_999"
,
names
[
5
]);
...
@@ -345,7 +345,7 @@ TEST_F(VariableTest, latency_recorder) {
...
@@ -345,7 +345,7 @@ TEST_F(VariableTest, latency_recorder) {
ASSERT_EQ
(
11UL
,
names
.
size
());
ASSERT_EQ
(
11UL
,
names
.
size
());
ASSERT_EQ
(
"ba_na_na_count"
,
names
[
0
]);
ASSERT_EQ
(
"ba_na_na_count"
,
names
[
0
]);
ASSERT_EQ
(
"ba_na_na_latency"
,
names
[
1
]);
ASSERT_EQ
(
"ba_na_na_latency"
,
names
[
1
]);
ASSERT_EQ
(
"ba_na_na_latency_
5
0"
,
names
[
2
]);
ASSERT_EQ
(
"ba_na_na_latency_
8
0"
,
names
[
2
]);
ASSERT_EQ
(
"ba_na_na_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"ba_na_na_latency_90"
,
names
[
3
]);
ASSERT_EQ
(
"ba_na_na_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"ba_na_na_latency_99"
,
names
[
4
]);
ASSERT_EQ
(
"ba_na_na_latency_999"
,
names
[
5
]);
ASSERT_EQ
(
"ba_na_na_latency_999"
,
names
[
5
]);
...
...
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