Have you ever wondered how you can build a highly available & resilient Docker Repository to store your Docker Images ?
data:image/s3,"s3://crabby-images/1167a/1167ae0881542584bffc9ca056acedc310f1a353" alt=""
In this post, we will setup an EC2 instance inside a Security Group and create an A record pointing to the server Elastic IP address as follow:
data:image/s3,"s3://crabby-images/0f203/0f203348af1feb05371dd3a123c03a44c90f26d6" alt=""
To provision the infrastructure, we will use Terraform as IaC (Infrastructure as Code) tool. The advantage of using this kind of tools is the ability to spin up a new environment quickly in different AWS region (or different IaaS provider) in case of incident (Disaster recovery).
Start by cloning the following Github repository:
1 | git clone https://github.com/mlabouardy/terraform-aws-labs.git |
Inside docker-registry folder, update the variables.tfvars with your own AWS credentials (make sure you have the right IAM policies).
1 | resource "aws_instance" "default" { |
I specified a shell script to be used as user_data when launching the instance. It will simply install the latest version of Docker CE and turn the instance to Docker Swarm Mode (to benefit from replication & high availability of Nexus container)
1 | #!/bin/sh |
Note: Surely, you can use a Configuration Management Tools like Ansible or Chef to provision the server once created.
Then, issue the following command to create the infrastructure:
1 | terraform apply -var-file=variables.tfvars |
Once created, you should see the Elastic IP of your instance:
data:image/s3,"s3://crabby-images/6ef34/6ef344aa4c2156a24a9ca3b07e888b77952eec0b" alt=""
Connect to your instance via SSH:
1 | ssh ec2-user@35.177.167.36 |
Verify that the Docker Engine is running in Swarm Mode:
data:image/s3,"s3://crabby-images/5ce6d/5ce6d92b3f282a4b3356e2c058f95cacbe4477c0" alt=""
Check if Nexus service is running:
data:image/s3,"s3://crabby-images/153c4/153c46104eb769be72a2c335247409264e0f27e6" alt=""
If you go back to your AWS Management Console. Then, navigate to Route53 Dashboard, you should see a new A record has been created which points to the instance IP address.
data:image/s3,"s3://crabby-images/742e8/742e8510a5c6e2bcdb6b6f4ba1c9f8775e77c546" alt=""
Point your favorite browser to the Nexus Dashboard URL (registry.slowcoder.com:8081). Login and create a Docker hosted registry as below:
data:image/s3,"s3://crabby-images/ef7b6/ef7b630b538c43fc53d2e06ba0ff89cf457bef30" alt=""
Edit the /etc/docker/daemon.json file, it should have the following content:
1 | { |
Note: For production it’s highly recommended to secure your registry using a TLS certificate issued by a known CA.
Restart Docker for the changes to take effect:
1 | service docker restart |
Login to your registry with Nexus Credentials (admin/admin123):
data:image/s3,"s3://crabby-images/5b867/5b867a24c3ac27b489d9bb3ea6842c28ca6860f7" alt=""
In order to push a new image to the registry:
1 | docker push registry.slowcoder.com:5000/mlabouardy/movies-api:1.0.0-beta |
data:image/s3,"s3://crabby-images/a6d69/a6d69b45bddc4919b4df4eccbf3d4ee7022621d4" alt=""
Verify that the image has been pushed to the remote repository:
data:image/s3,"s3://crabby-images/80433/80433aaf26452d7fd3f2a3a6b64abc40a3d21e16" alt=""
To pull the Docker image:
1 | docker pull registry.slowcoder.com:5000/mlabouardy/movies-api:1.0.0-beta |
data:image/s3,"s3://crabby-images/c950c/c950c38f8c1793e7c4712973a8cd522255fda809" alt=""
Note: Sometimes you end up with many unused & dangling images that can quickly take significant amount of disk space:
data:image/s3,"s3://crabby-images/501c2/501c26c35fb8a74866f4ac09152dce665215d94e" alt=""
You can either use the Nexus CLI tool or create a Nexus Task to cleanup old Docker Images:
data:image/s3,"s3://crabby-images/210b7/210b738d3713956d0ff3de45134d0d2ca3eb935e" alt=""
Populate the form as below:
data:image/s3,"s3://crabby-images/93512/93512a8ea807ddbdfb7e8fc64b123385b2b80120" alt=""
The task above will run everyday at midnight to purge unused docker images from “mlabouardy” registry.
Drop your comments, feedback, or suggestions below — or connect with me directly on Twitter @mlabouardy.