Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Combined Metrics API updates for v0.3 (Add Observer instrument, remove Gauge instrument, etc.) #430

Merged
merged 57 commits into from
Feb 14, 2020
Merged
Changes from 1 commit
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
3e17050
Gauge/Observer rewrite pt 1
Jan 23, 2020
56e1606
Checkpoint
Jan 28, 2020
4f4f4f8
Checkpoint
Jan 28, 2020
12339db
Optional features restored
Jan 28, 2020
5945fa3
Update selection process
Jan 29, 2020
da61304
Update TOC
Jan 29, 2020
c70cc97
Upstream
Jan 29, 2020
cc9caef
Reword intro para on standard impl
Jan 29, 2020
210491e
Add detail on label set
Jan 29, 2020
891759e
Add examples
Jan 30, 2020
a68d28c
Misspellings
Feb 4, 2020
610056b
Rewrite the introductory material
Feb 5, 2020
4f85830
Add a section on time
Feb 6, 2020
23a3430
Clarify 'standard implementation' and 'default interpretation'
Feb 6, 2020
c97fefd
Explain aggregations; Discourage timestamp use
Feb 6, 2020
ab5088c
Reword the metric event format
Feb 6, 2020
da8f189
Update Counter and Measure
Feb 6, 2020
afa0bb1
Update Observer (partial)
Feb 6, 2020
a0730c6
Remove options, discuss views API
Feb 6, 2020
e1298ea
Fixes
Feb 7, 2020
cf896f3
Fixes
Feb 7, 2020
baba6e4
Fixes
Feb 7, 2020
12753e0
Rename BoundTimer
Feb 11, 2020
b3da9d1
Typos and suggestions
Feb 11, 2020
445a8a8
Reword global Meter
Feb 11, 2020
3325599
Rearrange early paragraphs
Feb 11, 2020
21fd3e0
Use _run time_ and _simultaneous_
Feb 11, 2020
bb16feb
Rearrange early paragraphs (again)
Feb 11, 2020
01ae0d5
Define _run time_
Feb 11, 2020
f92b42b
These
Feb 11, 2020
d651afa
Iterate
Feb 11, 2020
49c19d4
Remove a TODO
Feb 11, 2020
a53ad58
More on global/named meters
Feb 11, 2020
313cd32
Difference, Capture
Feb 11, 2020
968caff
Timer wording
Feb 11, 2020
0faf458
Explicit timestamp
Feb 11, 2020
0081967
Rewrite simultaneous
Feb 11, 2020
bd1e06f
Example: active requests
Feb 11, 2020
b0ef3e4
Synchronously
Feb 11, 2020
cb3d369
Wording
Feb 11, 2020
dc61b4e
Example using correlation context
Feb 11, 2020
6dce940
Detail on WithKeys
Feb 11, 2020
ec8b3d5
Counter is a special case
Feb 11, 2020
775725f
Counter fixes; typo
Feb 11, 2020
245db59
Typo
Feb 11, 2020
81ac205
Split the leading example into Counter and Measure cases
Feb 11, 2020
7b56958
Remove poor example
Feb 11, 2020
52be8c9
Upstream
Feb 11, 2020
dfe0446
Update TOC
Feb 11, 2020
641a397
Add note about Observer and Context
Feb 11, 2020
c1b7c10
Add note about context-freedom in Observer
Feb 11, 2020
6accb05
Run MDL
Feb 11, 2020
18bdaa8
WithRecommendedKeys
Feb 11, 2020
e51023d
Typo
Feb 12, 2020
6ebfb6e
Address most of Bogdan's feedback
Feb 13, 2020
9f186b5
Typo
Feb 13, 2020
2a74584
Merge branch 'master' into jmacd/api-metrics-03
bogdandrutu Feb 14, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Split the leading example into Counter and Measure cases
  • Loading branch information
jmacd committed Feb 11, 2020
commit 81ac2057dad77365f0961f2e79d980972977a1f8
35 changes: 26 additions & 9 deletions specification/api-metrics.md
Original file line number Diff line number Diff line change
Expand Up @@ -470,23 +470,40 @@ change of state in the program.

## Examples

### Reporting bytes read and written
### Reporting total bytes read

You wish to monitor the number of bytes read and written from a
messaging server that supports several protocols. The number of bytes
read and written should be labeled with the protocol name and
aggregated in the process.
You wish to monitor the total number of bytes read from a messaging
server that supports several protocols. The number of bytes read
should be labeled with the protocol name and aggregated in the
process.

This is a typical application for the Counter instrument. Use one
Counter for bytes read and one Counter for bytes written. When
handling a request, compute a LabelSet containing the name of the
protocol and potentially other useful labels, then call `Add()` twice
with the same label set and the number of bytes read and written.
Counter for capturing the number bytes read. When handling a request,
compute a LabelSet containing the name of the protocol and potentially
other useful labels, then call `Add()` with the same label set and the
number of bytes read.

To lower the cost of this reporting, you can `Bind()` the
instrument with each of the supported protocols ahead of time and
avoid computing the label set for each request.

### Reporting total bytes read and bytes per request

You wish to monitor the total number of bytes read as well as the
number of bytes read per request, to have observability into total
traffic as well as typical request size. As with the example above,
these metric events should be labeled with a protocol name.

This is a typical application for the Measure instrument. Use one
Measure for capturing the number of bytes per request. A sum
aggregation applied to this data yields the total bytes read; other
aggregations allow you to export the minimum and maximum number of
bytes read, as well as the average value, and quantile estimates.

In this case, the guidance is to create a single instrument. Do not
create a Counter instrument to export a sum when you want to export
other summary statistics using a Measure instrument.

### Reporting per-request CPU usage

Suppose you have a way to measure the CPU usage of processing an
jmacd marked this conversation as resolved.
Show resolved Hide resolved
Expand Down