Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yabeda-rb/yabeda-datadog
Yabeda Datadog adapter. Collect and send custom metrics from Ruby apps to Datadog.
https://github.com/yabeda-rb/yabeda-datadog
datadog metrics monitoring yabeda
Last synced: 11 days ago
JSON representation
Yabeda Datadog adapter. Collect and send custom metrics from Ruby apps to Datadog.
- Host: GitHub
- URL: https://github.com/yabeda-rb/yabeda-datadog
- Owner: yabeda-rb
- License: mit
- Created: 2018-12-09T21:40:17.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2021-10-19T20:04:59.000Z (about 3 years ago)
- Last Synced: 2024-05-10T22:02:09.666Z (8 months ago)
- Topics: datadog, metrics, monitoring, yabeda
- Language: Ruby
- Homepage:
- Size: 77.1 KB
- Stars: 13
- Watchers: 3
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Yabeda Datadog adapter
[Yabeda](https://github.com/yabeda-rb/yabeda) adapter for easy exporting collected custom metrics from your application to the Datadog API.
## Prerequisites
Have an instance of Datadog agent and dogstats-d running. For installation options of Datadog agent please refer to [Datadog agent documentation](https://docs.datadoghq.com/agent/).
## Installation
Add to your application's Gemfile:
```ruby
gem "yabeda-datadog"
```And then execute:
$ bundle
## Usage
### Define metrics
Define Yabeda metrics to collect. Refer to [Yabeda documentation](https://github.com/yabeda-rb/yabeda) for instruction on how to configure and use Yabeda metrics.
Please note when configuring Yabeda you have to use [Datadog units](https://docs.datadoghq.com/developers/metrics/#units).
If a unit of a metric is not supported by Datadog, unit information will not be submitted to Datadog. However, the rest of the metric information will be updated.
You always have the ability to update it manually in Datadog metrics dashboard or by calling API by yourself.Refer to [Datadog metrics documentation](https://docs.datadoghq.com/graphing/metrics/) for working with your metrics in Datadog dashboard.
### Configure the adapter
You can configure with either `APP_ROOT/config/yabeda_datadog.yml` file or with environment variables.
Rails 5.1 users able to use encrypted rails secrets `Rails.application.secrets.yabeda_datadog.*`.Example of `yabeda_datadog.yml` file:
```yaml
# required (if missing adapter is no-op)
api_key:
app_key:# optional, default values used as an example
# how many queued metrics metrics sends in batches
batch_size: 10
# how many metrics you can queue for sending
queue_size: 1000
# threads to sends enqueued metrics
num_threads: 2
# Datadog agent host and port
agent_host: localhost
agent_port: 8125
# Logging severity threshold, you have to pass integer related to Logger Ruby class
# has 1 value by default which is Logger::INFO
log_level: 1
```Example of environment variables:
```shell
# required (if missing adapter is no-op)
YABEDA_DATADOG_API_KEY=
YABEDA_DATADOG_APP_KEY=# optional, default values used as an example
# how many queued metrics metrics sends in batches
YABEDA_DATADOG_BATCH_SIZE=10
# how many metrics you can queue for sending
YABEDA_DATADOG_QUEUE_SIZE=1000
# threads to sends enqueued metrics
YABEDA_DATADOG_NUM_THREADS=2
# Datadog agent host and port
YABEDA_DATADOG_AGENT_HOST=localhost
YABEDA_DATADOG_AGENT_PORT=8125
# Logging severity threshold, you have to pass integer related to Logger Ruby class
# has 1 value by default which is Logger::INFO
YABEDA_DATADOG_LOG_LEVEL=1
```You can obtain your Datadog API keys in [Datadog dashboard](https://app.datadoghq.com/account/settings#api).
Please note, when filling the queue (queue size option), your application will be blocked by waiting for a place in the queue.
You may specify `YABEDA_DATADOG_AGENT_HOST` and/or `YABEDA_DATADOG_AGENT_PORT` environment variables if your Datadog agent is running not on the same host as an app/code that collects metrics.
### Start the adapter
To start collecting and sending your metrics to Datadog agent run:
```ruby
Yabeda::Datadog.start
```**NOTE**: if you're using Ruby <2.5.2 you might encounter [a bug related to the process forking](https://bugs.ruby-lang.org/issues/14634) (e.g. when using Puma web server). The workaround is to start `Yabeda::Datadog` after the `fork` (e.g. when using Puma, put `Yabeda::Datadog.start` inside the `on_worker_boot` callback).
To star collecting Yabeda collect blocks (aka collectors) run the command:
```ruby
Yabeda::Datadog.start_exporter# optionaly you can pass collect_interval argument
TEN_SECONDS = 10
Yabeda::Datadog.start_exporter(collect_interval: TEN_SECONDS)
```### Limitations
On the first run of your application you will see such error messages in your logs:
ERROR -- yabeda_datadog: metric registration failed for yourapp.some_metric: metric_name not found
This is happening because metrics have not yet been collected and pushed to the DataDog (it may take up to the minute). So update metric metadata request to DataDog is failing.
This error will disappear on next run when all metrics' data reach DataDog and DataDog will be aware of it.
### Example
[yabeda-datadog-sidekiq-example](https://github.com/shvetsovdm/yabeda-datadog-sidekiq-example)
### Alternatives
Using [Prometheus support for Datadog Agent 6](https://www.datadoghq.com/blog/monitor-prometheus-metrics/) with [yabeda-prometheus](https://github.com/yabeda-rb/yabeda-prometheus).
## Contributing
Please see [CONTRIBUTING guide](/CONTRIBUTING.md).
Bug reports and pull requests are welcome on GitHub at [https://github.com/shvetsovdm/yabeda-datadog](https://github.com/shvetsovdm/yabeda-datadog).
### Releasing
1. Bump version number in `lib/yabeda/datadog/version.rb`
In case of pre-releases keep in mind [rubygems/rubygems#3086](https://github.com/rubygems/rubygems/issues/3086) and check version with command like `Gem::Version.new(Yabeda::Datadog::VERSION).to_s`
2. Fill `CHANGELOG.md` with missing changes, add header with version and date.
3. Make a commit:
```sh
git add lib/yabeda/datadog/version.rb CHANGELOG.md
version=$(ruby -r ./lib/yabeda/datadog/version.rb -e "puts Gem::Version.new(Yabeda::Datadog::VERSION)")
git commit --message="${version}: " --edit
```4. Create annotated tag:
```sh
git tag v${version} --annotate --message="${version}: " --edit --sign
```5. Fill version name into subject line and (optionally) some description (list of changes will be taken from changelog and appended automatically)
6. Push it:
```sh
git push --follow-tags
```7. GitHub Actions will create a new release, build and push gem into RubyGems! You're done!
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).