To simplify shipping metrics from one or many sources, we created Docker Metrics Collector. Docker Metrics Collector is a container that runs Metricbeat with the modules you enable at runtime.
Docker Metrics Collector ships metrics only. If you want to ship logs to Logz.io, see docker-collector-logs.
Download the Docker Metrics Collector image:
docker pull logzio/docker-collector-metrics
You'll set your configuration using environment variables
in the docker run
command.
Each parameter is formatted like this:
--env ENV_VARIABLE_NAME="value"
.
For a complete list of options, see the parameters below the code block and in the Modules section at the bottom of this doc. 👇
docker run --name docker-collector-metrics \
--env LOGZIO_TOKEN="<<SHIPPING-TOKEN>>" \
--env LOGZIO_MODULES="<<MODULES>>" \
logzio/docker-collector-metrics
Note: Documentation for specific modules is covered in the Modules section at the bottom of this doc.
Parameter | Description |
---|---|
LOGZIO_TOKEN (Required) | Your Logz.io account token. Replace <<SHIPPING-TOKEN>> with the token of the account you want to ship to. |
LOGZIO_MODULES (Required) | Comma-separated list of Metricbeat modules to be enabled on this container (formatted as "module1,module2,module3" ). To use a custom module configuration file, mount its folder to /logzio/modules . |
LOGZIO_REGION | Two-letter region code, or blank for US East (Northern Virginia). This determines your listener URL (where you're shipping the logs to) and API URL. You can find your region code in the Regions and URLs table. |
LOGZIO_TYPE (Default: docker-collector-metrics ) |
This field is needed only if you're shipping metrics to Kibana and you want to override the default value. In Kibana, this is shown in the type field. Logz.io applies parsing based on type . |
LOGZIO_LOG_LEVEL (Default: "INFO" ) |
The log level the module startup scripts will generate. |
LOGZIO_EXTRA_DIMENSIONS | Semicolon-separated list of dimensions to be included with your metrics (formatted as dimensionName1=value1;dimensionName2=value2 ). To use an environment variable as a value, format as dimensionName=$ENV_VAR_NAME . Environment variables must be the only value in the field. If an environment variable can't be resolved, the field is omitted. |
DEBUG (Default: false ) |
Set to true if you want Metricbeat to run in debug mode.Note: Debug mode tends to generate a lot of debugging output, so you should probably enable it temporarily only when an error occurs while running the docker-collector in production. |
HOSTNAME (Default: '' ) |
Insert your host name if you want it to appear in the metrics' host.name . If no value entered, host.name will show the container's ID. |
CLOUD_METADATA (Default: "false" ) |
Set to true enriches each event with instance metadata from the machine’s hosting provider. |
Give your metrics a few minutes to get from your system to ours, and then open Logz.io.
You can view your metrics in Grafana. We offer preconfigured dashboards for several sources, which you can find by clicking > Manage in the left menu.
If you're collecting metrics from your Docker containers,
you'll need to include docker
in the LOGZIO_MODULES
environment variable
and to mount docker.sock
at runtime.
For example:
docker run --name docker-collector-metrics \
--env LOGZIO_TOKEN="<<SHIPPING-TOKEN>>" \
--env LOGZIO_MODULES="docker" \
-v /var/run/docker.sock:/var/run/docker.sock:ro \
logzio/docker-collector-metrics
Parameter | Description |
---|---|
DOCKER_MATCH_CONTAINER_NAME | Comma-separated list of containers you want to collect the metrics from. If a container's name partially matches a name on the list, that container's metrics are shipped. Otherwise, its metrics are ignored. Note: Can't be used with DOCKER_SKIP_CONTAINER_NAME . |
DOCKER_SKIP_CONTAINER_NAME | Comma-separated list of containers you want to ignore. If a container's name partially matches a name on the list, that container's metrics are ignored. Otherwise, its metrics are shipped. Note: Can't be used with DOCKER_MATCH_CONTAINER_NAME . |
DOCKER_PERIOD (Default: 10s ) |
Sampling rate of metrics. The Docker API takes up to 2 seconds to respond, so we recommend setting this to 3s or longer. |
DOCKER_CERTIFICATE_AUTHORITY | Filepath to certificate authority for connecting to Docker over TLS. |
DOCKER_CERTIFICATE | Filepath to CA certificate for connecting to Docker over TLS. |
DOCKER_KEY | Filepath to Docker key for connecting to Docker over TLS. |
For the AWS module,
you'll need to include aws
in the LOGZIO_MODULES
environment variable.
For example:
docker run --name docker-collector-metrics \
--env LOGZIO_TOKEN="<<SHIPPING-TOKEN>>" \
--env LOGZIO_MODULES="aws" \
--env AWS_ACCESS_KEY_ID="<<ACCESS-KEY>>" \
--env AWS_SECRET_ACCESS_KEY="<<SECRET-KEY>>" \
--env AWS_DEFAULT_REGION="<<AWS-REGION>>" \
--env AWS_NAMESPACES="<<NAMESPACES>>" \
logzio/docker-collector-metrics
You'll also need to set up an IAM user with the permissions to fetch the right metrics, and the region you're fetching metrics from.
Note: extra charges on AWS API requests may be generated by this module.
You'll need to specify the AWS region you're collecting metrics from.
Find your region's slug in the region menu (in the top menu, on the right side).
For example: The slug for US East (N. Virginia) is "us-east-1", and the slug for Canada (Central) is "ca-central-1".
Paste your region slug in your text editor. You'll need this for your Metricbeat configuration later.
Parameter | Description |
---|---|
AWS_ACCESS_KEY_ID | Your IAM user's access key ID. |
AWS_SECRET_ACCESS_KEY | Your IAM user's secret key. |
AWS_SESSION_TOKEN | Your IAM user's session token. |
AWS_ROLE_ARN | Your IAM role to assume. |
AWS_DEFAULT_REGION (Required) | Your region's slug. You can find this in the AWS region menu (in the top menu, to the right). |
AWS_CREDENTIAL_PROFILE_NAME | Your profile name in shared credentials file. |
AWS_SHARED_CREDENTIAL_FILE | Your directory of the shared credentials file, in your docker instance. Note: If you're using this parameter, you'll have to mount your credentials folder, meaning you'll need to add to your docker run command the line: -v /path/to/your/aws/credentials/folder:<<path/to/shared/credential/file/in/docker>>:ro . You'll also need to have an ARN role set either on your credential file or with the parameter AWS_ROLE_ARN . |
AWS_NAMESPACES (Required) | Comma-separated list of namespaces of the metrics you want to collect. You can find a complete list of namespaces at AWS Services That Publish CloudWatch Metrics |
About how to use aws credentials, you can refer AWS Credentials Configration
Note: This Docker container monitors Linux system metrics only. For other OSes, we recommend running Metricbeat locally on the system itself.
For the system module,
you'll need to include system
in the LOGZIO_MODULES
environment variable.
Use this to monitor Linux systems only, for other types of system like OSX/Windows use Metricbeat locally.
For example:
docker run --name docker-collector-metrics \
--env LOGZIO_TOKEN="<<SHIPPING-TOKEN>>" \
--env LOGZIO_MODULES="system" \
--volume="/var/run/docker.sock:/var/run/docker.sock:ro" \
--volume="/sys/fs/cgroup:/hostfs/sys/fs/cgroup:ro" \
--volume="/proc:/hostfs/proc:ro" \
--volume="/:/hostfs:ro" \
--net=host \
logzio/docker-collector-metrics
- 0.2.1:
- Supports more AWS credentials (thanks @NingPekin!).
- Refactored aws params.
- 0.2.0:
- Breaking change: Upgraded to Metricbeat 7.10.
- 0.1.6:
- Supports adding cloud metadata.
- 0.1.5:
- Supports adding hostname.
- 0.1.4:
- Supporting debug mode.
- 0.1.3:
- Updated new public SSL certificate in Docker image & Metricbeat configuration.
- 0.1.2:
- Pulling metrics from custom AWS namespaces.
- 0.1.1:
- Pulling tags from AWS services.
- 0.1.0:
- Upgraded to metricbeat 7.5.2.
- Renamed
LOGZIO_ADDITIONAL_FIELDS
toLOGZIO_EXTRA_DIMENSIONS
. Dimensions will arrive underdim
. - Deprecated
LOGZIO_URL
. We are now supportingLOGZIO_REGION
. - Added AWS module.
- 0.0.5:
- Added docker module.
- 0.0.4:
- Refactor the image to use default Metricbeat yamls.
- 0.0.3: BREAKING CHANGES:
- using beats7
- supporting multiple modules
- 0.0.2: added the ability to set the type to fetched metrics.