Table of Contents
- What is Docker?
- How does Docker work?
- How is a docker container built?
- What are docker registries?
- Commands Crash Course
- Final Thoughts
The containerization revolution has just begun, which means you have heard about docker at least once in your professional life. Containerization has made our apps’ deployment cycle faster and efficient. Leading the containerization wave is docker, the most popular container runtime.
Containers, containerization doesn’t click so well? Read this curated post to get accustomed to every prerequisite.
Back to dockers, and in this post, we would dive into this topic and understand its ins and outs with a high-level overview.
What is Docker?
Docker is a tool or platform that makes it easier to create, deploy, package, and ship applications and their components like libraries and other dependencies together. Its main goal is to simplify the application deployment process on Linux. Linux because it’s the most used server OS.
The container runtime enables many containers to operate on the same hardware (aka virtualization), resulting in increased efficiency, isolation of applications, and ease of configuration.
How does Docker work?
Docker packs an application and all of its dependencies in a virtual container that can be run on any Linux server. To function the docker container is composed of the following components:
Daemon: The Docker daemon ( dockerd ) manages Docker resources such as images, containers, networks, and volumes by listening for Docker API requests. To control Docker services, a daemon may interact with other daemons.
High-Level REST API: It allows users to communicate with the daemon or the dockerd.
A CLI: It is a command-line tool (aka docker client) that lets you talk to the Docker daemon.
How is a docker container built?
Docker containers are built using a docker image which in turn is created using a
dockerfile consists of the instructions which are needed to build a docker image. Every time you run a new command, a new layer is built on top of the existing layer in the docker image called intermediate images.
A simple Node.js docker file:
FROM node:stable COPY . /usr/src/app/ RUN npm install && npm run build EXPOSE 3000 ENTRYPOINT ["npm", "start"]
What is a docker image?
If you build using the
dockerfile, the result is called a docker image. To build use the command
docker build. The docker image is layered and hashed, with each layer containing new instructions.
Since all layers are hashed, Docker can cache them and reduce build times for layers that don’t change between builds. If the COPY phase hasn’t changed, you won’t have to restore and re-copy any of the files, saving you a lot of time in the build process.
Docker builds a new thin writable layer on top of all other layers at the end of the build process.
So, what’s the docker container?
The docker container is the running instance of the docker image.
We can sum things up as:
dockerfileis a recipe for creating Docker images
- A Docker image gets built by running a Docker command (which uses that
- A Docker container is a running instance of a Docker image
What are docker registries?
It’s not always necessary that you need to build all the images on your own using custom dockerfile. It’s a common practice to pull images (use
docker pull) from Docker registries or the store containing many prebuilt images.
So common that if you pick a course, you will interact with pulling docker images from repositories and not building from your own
Docker provides an option to have public or private (for inter-organization use) registries to help you with the hassle of building images on your own every time. You can get images from them and also upload your own images to use later on by using
Commands Crash Course
You might have come across many commands in this post, and this section summarizes all of these commands for you to reference.
$ docker build
This command is used to build a fresh image from your docker file and store it to your local docker image directory. This image can later be published to registry.
$ docker pull
This command lets you pull an existing image from a docker registry and save it to your local docker image directory. Later on, this image can be used to spin up containers.
$ docker run
This command lets you run a container out of an existing container image.
$ docker push
This command helps you to push an image or a repository to a registry.
I hope this post helped you understand docker and its key terminologies besides the back-end with the daemon and APIs. Docker is a leap, and if you want to explore more, like why docker is better than VMs.
You can read this post.
Interested in best containerization practices? Here we go!
That’s it for now, then. Thanks for reading, and don’t forget to check the official docker docs for more information.