Monitoring Containers with Prometheus

Hands-On Lab


Photo of Travis Thomsen

Travis Thomsen

Course Development Director in Content





For the last six months, the Acme Anvil Corporation has been migrating some of their bare metal infrastructure to Docker containers. It’s time to implement some basic monitoring in the environment. You will handle this in two ways: using Docker stats and Prometheus. Your mission is to set up Prometheus and cAdvisor using Docker Compose. You can get more information on Prometheus at

What are Hands-On Labs?

Hands-On Labs are scenario-based learning environments where learners can practice without consequences. Don't compromise a system or waste money on expensive downloads. Practice real-world skills without the real-world risk, no assembly required.

Monitoring Containers With Prometheus


Hi there, and welcome. In this lab, we'll walk through how to monitor containers using Docker stats, Prometheus, and cAdvisor.

Getting In

Log into the server using the credentials provided by the lab, and then become the root user with a sudo su -. We're ready to go.

Create prometheus.yml

In root's home directory, create prometheus.yml:

vi prometheus.yml

We've got to stick a few configuration lines in here. When we're done, it should look like this:

- job_name: cadvisor
  scrape_interval: 5s
  - targets:
    - cadvisor:8080

Create the Prometheus Services

In order to set up Prometheus services, we've got to create configuration files. We're going to make docker-compose.yml, right here in the same directory:

vi docker-compose.yml

It should look like this when we're finished with it:

version: '3'
    image: prom/prometheus:latest
    container_name: prometheus
      - 9090:9090
      - --config.file=/etc/prometheus/prometheus.yml
      - ./prometheus.yml:/etc/prometheus/prometheus.yml
      - cadvisor

    image: google/cadvisor:latest
    container_name: cadvisor
      - 8080:8080
      - /:/rootfs:ro
      - /var/run:/var/run:rw
      - /sys:/sys:ro
      - /var/lib/docker:/var/lib/docker:ro

In order to stand up the environment, we'll run this:

docker-compose up -d

And to see if everything stood up properly, let's run a quick docker ps. The output should show four containers: prometheus, cadvisor, nginx, and redis.

Viewing the Prometheus Web Interface

Let's so see in a web browser as well. Grab the public IP from the lab page, and browse to it, using the correct port number: http://<IP_ADDRESS>:9090/graph/

We should see a Prometheus page. Click on Status in the top menu, and pick Targets. Now we should land on a screen showing a link for cadvisor.

Now let's click on Graph (again, in the top menu). There's an Execute button. In the dropdown next to it, find container_startup_time_second. Then click Execute. Just below, we'll see Graph and Console tabs. They've each got the container startup time information we were hunting for. One tab is just prettier than the other.

Just above that *Execute button and related dropdown is a web form field where we can type different expressions. Let's try that now, sticking rate(container_cpu_usage_seconds_total{name="redis"}[1m]) in there. We can do this instead of using the dropdown if we want. If we hit Execute, the information below changes to reflect our new "query."

Investigating cAdvisor

In a browser, navigate to http://<IP_ADDRESS>:8080/containers/. Take a peek around, then change the URL to one of our container names (like nginx) so we're at http://<IP_ADDRESS>:8080/docker/nginx/.

Stats in Docker

If we run docker stats, we're going to get some output that looks a lot like docker ps, but this stays open and reports what's going on as far as the various aspects (CPU and memory usage, etc.) of our containers.

To get out of this, hit Ctrl+C

Prettier Stats

We can format the output of docker stats differently if we want. And, if we really want to get fancy, we can do it in a shell script. Let's do it.

Create a file in /root:

vi ~/

Now let's fill it with this command:

docker stats --format "table {{.Name}} {{.ID}} {{.MemUsage}} {{.CPUPerc}}"

Once we've made sure the file is executable (chmod a+x we can run it with this:


Just like before, when we get bored watching stats, we can exit by pressing Ctrl+C


Well then, looks like we're finished here. We got Prometheus running, and we're able to monitor our containers with it. Congratulations!