diff --git a/_data/authors.yml b/_data/authors.yml index ec3605c90733d..c8b58e89930af 100644 --- a/_data/authors.yml +++ b/_data/authors.yml @@ -86,4 +86,10 @@ daniel_bryant: name: Daniel Bryant email: daniel.bryant@opencredo.com github: danielbryantuk - twitter: danielbryantuk + twitter: danielbryantuk +markus_wehrle: + name: Markus Wehrle + email: markuus.wehrle@haufe-lexware.com + github: markus2810 + linkedin: markus-wehrle-37ab01a7 + diff --git a/_posts/2017-03-30-monitoring-docker-environment.md b/_posts/2017-03-30-monitoring-docker-environment.md new file mode 100644 index 0000000000000..433ad65f5fd15 --- /dev/null +++ b/_posts/2017-03-30-monitoring-docker-environment.md @@ -0,0 +1,188 @@ +--- +layout: post +title: Monitoring a docker environment using TICK stack +subtitle: Get live metrics of your running containers and docker hosts in a rancher environment +category: howto +tags: [docker] +author: markus_wehrle +author_email: markus.wehrle@haufe-lexware.com +header-img: "images/bg-post.jpg" +--- + +## Requirements for monitoring +In an environment with multiple docker hosts and a bunch of containers there are new requirements regarding monitoring the infrastructure. +In addition to non-containerized environments where hosts or virtual machines and applications are monitored you want to get some information about your running containers like: +* Number of running or stopped containers in your environment +* Memory, CPU, IO load per container or per service +* Distribution of your containers or services over you hosts +* Access to meta data of your containers like version, image name, etc. +* more? + +## Environment +Some Code samples an explanations are specific for our environment, which uses the following tools: +* [Rancher](http://rancher.com/) as container orchestration plattform +* Docker hosts running on [AWS](https://aws.amazon.com) managed by rancher +* T,I and C of the influxdata [TICK stack](https://www.influxdata.com/open-source/). +* [Grafana](https://grafana.com/) for visualizing data replacing the Chronograph part of the TICK stack + +## Configure and roll out Telegraf +Assuming that Rancher, some docker hosts, an InfluxDB and Grafana is already in place and setup, we can start configuring telegraf and rolling it out on our docker hosts. +[Telegraf](https://docs.influxdata.com/telegraf/v1.2/) is responsible for collecting real time data. +###Create an adjusted telegraf container +First create a docker file for telegraf +```docker +# telegraf docker file +FROM debian:jessie +MAINTAINER Markus Wehrle + +ENV DEBIAN_FRONTEND noninteractive +ENV TELEGRAF_VERSION 1.1.1 + +RUN gpg \ + --keyserver hkp://ha.pool.sks-keyservers.net:80 \ + --keyserver-options http-proxy=http://10.12.1.236:8083 \ + --recv-keys 05CE15085FC09D18E99EFB22684A14CF2582E0C5 + +RUN apt-get update \ + && apt-get install -y wget \ + && wget -q https://dl.influxdata.com/telegraf/releases/telegraf_${TELEGRAF_VERSION}_amd64.deb.asc \ + && wget -q https://dl.influxdata.com/telegraf/releases/telegraf_${TELEGRAF_VERSION}_amd64.deb \ + && gpg --batch --verify telegraf_${TELEGRAF_VERSION}_amd64.deb.asc telegraf_${TELEGRAF_VERSION}_amd64.deb \ + && dpkg -i telegraf_${TELEGRAF_VERSION}_amd64.deb \ + && rm -f telegraf_${TELEGRAF_VERSION}_amd64.deb* + +ADD scripts/start_telegraf.sh / + +RUN chmod +x /start_telegraf.sh + +COPY conf/telegraf.conf /etc/telegraf/telegraf.conf + +ENTRYPOINT ["/start_telegraf.sh"] +```` +In the entry point script we fetch the name of our host from the rancher metadata service and pass it as an environment variable to telegraf +```bash +#!/bin/bash + +# get the host name for submit in monitoring +# set the env variable that is used in the telegraf config file +export INFLUX_TELEGRAF_HOST=$(curl "http://rancher-metadata/2015-07-25/self/host/hostname") +exec telegraf + +``` +The default config file of telegraf requires the following changes +####agent section +``` +[agent] + ## Override default hostname, if empty use os.Hostname() + hostname = "$INFLUX_TELEGRAF_HOST" +``` +####output section +``` +[[outputs.influxdb]] + ## The full HTTP or UDP endpoint URL for your InfluxDB instance. + ## Multiple urls can be specified as part of the same cluster, + ## this means that only ONE of the urls will be written to each interval. + # urls = ["udp://localhost:8089"] # UDP endpoint example + urls = ["$INFLUXDB_HOST"] # required + ## The target database for metrics (telegraf will create it if not exists). + database = "$INFLUXDB_NAME" # required + + ## Retention policy to write to. Empty string writes to the default rp. + retention_policy = "" + ## Write consistency (clusters only), can be: "any", "one", "quorum", "all" + write_consistency = "any" + + ## Write timeout (for the InfluxDB client), formatted as a string. + ## If not provided, will default to 5s. 0s means no timeout (not recommended). + timeout = "5s" + username = "$INFLUXDB_USER" + password = "$INFLUXDB_PASSWORD" + ```` +####inputs section +The inputs.docker section must be activated and should look like +```conf +# # Read metrics about docker containers + [[inputs.docker]] + ## Docker Endpoint + ## To use TCP, set endpoint = "tcp://[ip]:[port]" + ## To use environment variables (ie, docker-machine), set endpoint = "ENV" + endpoint = "unix:///var/run/docker.sock" + ## Only collect metrics for these containers, collect all if empty + container_names = [] + ## Timeout for docker list, info, and stats commands + timeout = "5s" + + ## Whether to report for each container per-device blkio (8:0, 8:1...) and + ## network (eth0, eth1, ...) stats or not + perdevice = true + ## Whether to report for each container total blkio and network stats or not + total = false + ``` + +###Roll it out on every docker host +Once your telegraf container is build and ready to deploy, you need to run it on every docker host in your environment. +####This is sample compose file: +```yml +version: '2' +services: + telegraf: + environment: + INFLUXDB_HOST: + INFLUXDB_NAME: + INFLUXDB_USER: + INFLUXDB_PASSWORD: + HOST_MOUNT_PREFIX: /hostfs + HOST_ETC: /hostfs/etc + image: + stdin_open: true + tty: true + labels: + io.rancher.container.pull_image: always + io.rancher.scheduler.global: 'true' + volumes: + - /var/run/docker.sock:/var/run/docker.sock:ro + - /sys:/rootfs/sys:ro + - /proc:/rootfs/proc:ro + - /etc:/rootfs/etc:ro + - /:/hostfs:ro + stdin_open: true + mem_limit: 16777216 +``` +Replace the parameters to fit your environment. +The rancher specific labels make sure, that the telegraf container is running on every host. +If you add additional host to the rancher environment, a telegraf container will be started on the newly added host and you will receive data of the new host instantly. + +##Create some nice dashboards +Now! Open grafana and add some panels to visualize your data. +A lot of new measurements should be available in the query editor of grafana. Measurements from containers starting with docker_ and basic metrics from the hosts themselves like cpu, disk, etc.. + +![measurements](/images/monitoring-docker-environment/measurements.png) + +All your hosts should be available as filter with the names you gave them in rancher. In our case rancher05 to rancher10. + +![hosts](/images/monitoring-docker-environment/hosts.png) + +As well as environments, stacks and services you defined in rancher or container image names including version and other custom meta data. + +![filter](/images/monitoring-docker-environment/filter.png) + +Combined with one of the field values, you can drill down to a single container measurement if required. + +![field](/images/monitoring-docker-environment/field.png) + +###Sample dashboard +This is one of our dashboards create using data collected with the configuration described above. + +![dashboard](/images/monitoring-docker-environment/dashboard.png) + +###Automatically add new hosts +In a docker environment hosts are added or removed over time. +You can add an additional query for each new host to be shown on the dashboard by cloning a previous one. +This would make a lot of work to keep your dashboards up to date over time. +But a simple GROUP BY "host" in the query will do this work for you. +```SQL +SELECT last("n_containers_running") as num FROM "autogen"."docker" WHERE $timeFilter GROUP BY "host", time($interval) fill(null) +``` +New hosts will be displayed in graph and legend automatically, while old are removed, if there is no data of them to display. +Historical data is kept and old hosts are shown when you scroll back in time. + diff --git a/images/monitoring-docker-environment/dashboard.png b/images/monitoring-docker-environment/dashboard.png new file mode 100644 index 0000000000000..dab63eb5c8105 Binary files /dev/null and b/images/monitoring-docker-environment/dashboard.png differ diff --git a/images/monitoring-docker-environment/field.png b/images/monitoring-docker-environment/field.png new file mode 100644 index 0000000000000..965d259a0d8d1 Binary files /dev/null and b/images/monitoring-docker-environment/field.png differ diff --git a/images/monitoring-docker-environment/filter.png b/images/monitoring-docker-environment/filter.png new file mode 100644 index 0000000000000..eddfc534b9dad Binary files /dev/null and b/images/monitoring-docker-environment/filter.png differ diff --git a/images/monitoring-docker-environment/hosts.png b/images/monitoring-docker-environment/hosts.png new file mode 100644 index 0000000000000..5d0ed8a7c56be Binary files /dev/null and b/images/monitoring-docker-environment/hosts.png differ diff --git a/images/monitoring-docker-environment/measurements.png b/images/monitoring-docker-environment/measurements.png new file mode 100644 index 0000000000000..b6dc0593d74ff Binary files /dev/null and b/images/monitoring-docker-environment/measurements.png differ