Monitoring application performance is crucial in modern DevOps workflows. Today, we'll take it a step further by integrating Docker container logs into Grafana for real-time visualization. This hands-on project adds a valuable skill to your resume while giving you practical experience in monitoring tools.
Let’s dive into what, why, and how to accomplish this task!
What Will You Do?
Install Docker on a Linux EC2 instance using User Data.
Deploy two Docker containers running a simple application (a To-Do app).
Configure Docker to send real-time logs to Grafana via Loki.
Visualize and analyze these logs in the Grafana UI.
Why Is This Important?
Centralized Monitoring: Grafana provides a unified dashboard to monitor logs from multiple containers.
Real-Time Insights: Logs are streamed in real-time, enabling quicker diagnosis of issues.
Resume-Worthy: Proficiency in tools like Docker, Grafana, and Loki demonstrates strong DevOps skills.
How to Accomplish This?
Step 1: Automate Docker Installation on EC2
Launch your Linux EC2 instance with the following User Data script to automatically install and start Docker:
#!/bin/bash
sudo yum update -y
sudo amazon-linux-extras install docker -y
sudo service docker start
sudo systemctl enable docker
sudo usermod -a -G docker ec2-user
This script ensures Docker is installed, the service is running, and the ec2-user
has permission to run Docker commands.
Step 2: Deploy Applications in Docker Containers
SSH into Your Instance:
Use your EC2 instance's public IP to connect.ssh -i <your-key.pem> ec2-user@<public-ip>
Run Two Docker Containers:
Pull a pre-built To-Do app image from Docker Hub and run two containers.docker pull <todo-app-image> docker run -d --name todo-app-1 -p 8081:80 <todo-app-image> docker run -d --name todo-app-2 -p 8082:80 <todo-app-image>
Replace
<todo-app-image>
with the actual image name from Docker Hub.
Access the applications athttp://<public-ip>:8081
andhttp://<public-ip>:8082
.
Step 3: Configure Docker to Send Logs to Grafana
Install Loki Docker Plugin:
docker plugin install grafana/loki-docker-driver:latest --alias loki --grant-all-permissions
Update Docker Configuration for Loki:
Edit the/etc/docker/daemon.json
file to configure the Loki logging driver.{ "log-driver": "loki", "log-opts": { "loki-url": "http://<loki-server>:3100/loki/api/v1/push" } }
Replace
<loki-server>
with your Loki server's IP or domain.Restart Docker Service:
sudo systemctl restart docker
Run Containers with Loki Logging:
Restart your containers with the Loki logging driver:docker run -d --name todo-app-1 -p 8081:80 \ --log-driver=loki \ --log-opt loki-url="http://<loki-server>:3100/loki/api/v1/push" \ <todo-app-image>
Step 4: Visualize Logs in Grafana
Add Loki as a Data Source:
Navigate to Configuration > Data Sources in Grafana.
Select Loki and set the URL to
http://<loki-server>:3100
.
Explore Logs:
Go to Explore in Grafana.
Use queries like
{container_name="todo-app-1"}
to view logs from specific containers.
Hands-On Tasks for Practice
Verify Docker Installation:
docker --version sudo systemctl status docker
Test Application Accessibility:
Access the To-Do app via your browser using:http://<public-ip>:8081 http://<public-ip>:8082
Explore Logs in Grafana:
Confirm real-time logs appear for both containers.
Conclusion
By completing this project, you’ve automated Docker setup, deployed applications in containers, and integrated real-time logs into Grafana. This workflow not only enhances your understanding of DevOps tools but also demonstrates your ability to manage and monitor containerized applications effectively.