83 lines
3.0 KiB
Markdown
83 lines
3.0 KiB
Markdown
|
# telemetry_poller
|
||
|
|
||
|
[![Codecov](https://codecov.io/gh/beam-telemetry/telemetry_poller/branch/master/graphs/badge.svg)](https://codecov.io/gh/beam-telemetry/telemetry_poller/branch/master/graphs/badge.svg)
|
||
|
|
||
|
Allows to periodically collect measurements and dispatch them as Telemetry events.
|
||
|
|
||
|
`telemetry_poller` by default runs a poller to perform VM measurements:
|
||
|
|
||
|
* `[vm, memory]` - contains the total memory, process memory, and all other keys in `erlang:memory/0`
|
||
|
* `[vm, total_run_queue_lengths]` - returns the run queue lengths for CPU and IO schedulers. It contains the `total`, `cpu` and `io` measurements
|
||
|
* `[vm, system_counts]` - returns the current process, atom and port count as per `erlang:system_info/1`
|
||
|
|
||
|
You can directly consume those events after adding `telemetry_poller` as a dependency.
|
||
|
|
||
|
Poller also provides a convenient API for running custom pollers.
|
||
|
|
||
|
## Defining custom measurements
|
||
|
|
||
|
Poller also includes conveniences for performing process-based measurements as well as custom ones.
|
||
|
|
||
|
### Erlang
|
||
|
|
||
|
First define the poller with the custom measurements. The first measurement is the built-in `process_info` measurement and the second one is given by a custom module-function-args defined by you:
|
||
|
|
||
|
```erlang
|
||
|
telemetry_poller:start_link(
|
||
|
[{measurements, [
|
||
|
{process_info, [{name, my_app_worker}, {event, [my_app, worker]}, {keys, [memory, message_queue_len]}]},
|
||
|
{example_app_measurements, dispatch_session_count, []}
|
||
|
]},
|
||
|
{period, timer:seconds(10)}, % configure sampling period - default is timer:seconds(5)
|
||
|
{name, my_app_poller}
|
||
|
]).
|
||
|
```
|
||
|
|
||
|
Now define the custom measurement and you are good to go:
|
||
|
|
||
|
```erlang
|
||
|
-module(example_app_measurements).
|
||
|
|
||
|
dispatch_session_count() ->
|
||
|
% emit a telemetry event when called
|
||
|
telemetry:execute([example_app, session_count], #{count => example_app:session_count()}, #{}).
|
||
|
```
|
||
|
|
||
|
### Elixir
|
||
|
|
||
|
First define the poller with the custom measurements. The first measurement is the built-in `process_info` measurement and the second one is given by a custom module-function-args defined by you:
|
||
|
|
||
|
```elixir
|
||
|
defmodule ExampleApp.Measurements do
|
||
|
def dispatch_session_count() do
|
||
|
# emit a telemetry event when called
|
||
|
:telemetry.execute([:example_app, :session_count], %{count: ExampleApp.session_count()}, %{})
|
||
|
end
|
||
|
end
|
||
|
```
|
||
|
|
||
|
```elixir
|
||
|
:telemetry_poller.start_link(
|
||
|
# include custom measurement as an MFA tuple
|
||
|
measurements: [
|
||
|
{:process_info, name: :my_app_worker, event: [:my_app, :worker], keys: [:message, :message_queue_len]},
|
||
|
{ExampleApp.Measurements, :dispatch_session_count, []},
|
||
|
],
|
||
|
period: :timer.seconds(10), # configure sampling period - default is :timer.seconds(5)
|
||
|
name: :my_app_poller
|
||
|
)
|
||
|
```
|
||
|
|
||
|
## Documentation
|
||
|
|
||
|
See [documentation](https://hexdocs.pm/telemetry_poller/) for more concrete examples and usage
|
||
|
instructions.
|
||
|
|
||
|
## Copyright and License
|
||
|
|
||
|
telemetry_poller is copyright (c) 2018 Chris McCord and Erlang Solutions.
|
||
|
|
||
|
telemetry_poller source code is released under Apache License, Version 2.0.
|
||
|
|
||
|
See [LICENSE](LICENSE) and [NOTICE](NOTICE) files for more information.
|