UNIT-4
Introduction to Docker
• Docker is an open-source centralized platform designed to create, deploy, and run applications. Docker uses
container on the host's operating system to run applications. It allows applications to use the same Linux
kernel as a system on the host computer, rather than creating a whole virtual operating system.
• Containers ensure that our application works in any environment like development, test, or production. Docker
includes components such as Docker client, Docker server, Docker machine, Docker hub, Docker composes,
etc.
Docker Features
• Although Docker provides lots of features, we are listing some major features which are given below.
• Easy and Faster Configuration
• Increase productivity
• Application Isolation
• Swarm
• Routing Mesh
• Services
• Security Management
Docker Engine
• It is a client server application that contains the following major components.
• A server which is a type of long-running program called a daemon process.
• The REST API is used to specify interfaces that programs can use to talk to the daemon and
instruct it what to do.
• A command line interface client.
Docker Architecture
Docker runs on the host operating system. It is responsible for running containers to manage
docker services. Docker daemon communicates with other daemons. It offers various Docker
objects such as images, containers, networking, and storage.
Docker architecture
Docker follows Client-Server architecture, which includes the three main components that are
Docker Client, Docker Host, and Docker Registry.
1. Docker Client
Docker client uses commands and REST APIs to communicate with the Docker Daemon (Server). When a client runs any
docker command on the docker client terminal, the client terminal sends these docker commands to the Docker daemon.
Docker daemon receives these commands from the docker client in the form of command and REST API's request.
Docker Client uses Command Line Interface (CLI) to run the following commands -
docker build
docker pull
docker run
2. Docker Host
Docker Host is used to provide an environment to execute and run applications. It contains the docker images,
containers, networks, and storage.
3. Docker Registry
Docker Registry manages and stores the Docker images.
There are two types of registries in the Docker -
Pubic Registry - Public Registry is also called as Docker hub.
Private Registry - It is used to share images within the enterprise.
4. Docker Images
Docker images are the read-only binary templates used to create Docker Containers. It uses a private
container registry to share container images within the enterprise and also uses public container registry
to share container images within the whole world. Metadata is also used by docket images to describe
the container's abilities.
5. Docker Containers
Containers are the structural units of Docker, which is used to hold the entire package that is needed to
run the application. The advantage of containers is that it requires very less resources. we can say that
the image is a template, and the container is a copy of that template.
6. Docker Networking
Using Docker Networking, an isolated package can be communicated. Docker contains the following network
drivers -
• Bridge - Bridge is a default network driver for the container. It is used when multiple docker communicates
with the same docker host.
• Host - It is used when we don't need for network isolation between the container and the host.
• None - It disables all the networking.
• Overlay - Overlay offers Swarm services to communicate with each other. It enables containers to run on the
different docker host.
7. Docker Storage
Docker Storage is used to store data on the container. Docker offers the following options for the Storage -
• Data Volume - Data Volume provides the ability to create persistence storage. It also allows us to name
volumes, list volumes, and containers associates with the volumes.
• Directory Mounts - It is one of the best options for docker storage. It mounts a host's directory into a
container.
• Storage Plugins - It provides an ability to connect to external storage platforms.
Docker installation and setup
We can install docker on any operating system like Windows, Linux, or Mac. Here, we are going to
install docker-engine on Windows. The main advantage of using Docker on Windows is that it
provides an ability to run natively on Windows without any kind of virtualization.
To install docker on windows, we need to download and install the Docker Toolbox.
Follow the below steps to install docker on windows -
Step1: Click on the below link to download DockerToolbox.exe.
https://download.docker.com/win/stable/DockerToolbox.exe
Step 2: Once the DockerToolbox.exe file is downloaded, double click on that file. The following window appears
on the screen, in which click on the Next.
Step 2: Once the DockerToolbox.exe file is downloaded, double click on that
file. The following window appears on the screen, in which click on the Next.
Working with Docker images and containers
Docker container is a running instance of an image. You can use Command Line Interface (CLI) commands
to run, start, stop, move, or delete a container. You can also provide configuration for the network and
environment variables. Docker container is an isolated and secure application platform, but it can share and
access to resources running in a different host or container.
An image is a read-only template with instructions for creating a Docker container. A docker image is
described in text file called a Dockerfile, which has a simple, well-defined syntax. An image does not have
states and never changes. Docker Engine provides the core Docker technology that enables images and
containers.
Docker Container
Docker container is a running instance of an image. You can use Command Line Interface (CLI) commands
to run, start, stop, move, or delete a container. You can also provide configuration for the network and
environment variables. Docker container is an isolated and secure application platform, but it can share and
access to resources running in a different host or container.
Docker file
A Dockerfile is a text document that contains commands that are used to assemble an image. We can use any
command that call on the command line. Docker builds images automatically by reading the instructions from
the Dockerfile.
The docker build command is used to build an image from the Dockerfile. You can use the -f flag with docker
build to point to a Dockerfile anywhere in your file system.
Docker - Compose
Docker Swarm
Kubernetes
Kubernetes is an open-source container orchestration platform originally developed by Google and now
maintained by the Cloud Native Computing Foundation (CNCF). It enables automated deployment, scaling,
and management of containerized applications across clusters of machines. Kubernetes helps organizations
transition from host-centric to container-centric infrastructure, improving resource utilization and operational
efficiency.
Kubernetes architecture
Kubernetes - Service
Kubernetes - Deployments
Deployments are upgraded and higher version of replication controller. They manage the deployment of replica
sets which is also an upgraded version of the replication controller. They have the capability to update the replica
set and are also capable of rolling back to the previous version.
They provide many updated features of match Labels and selectors. We have got a new controller in the
Kubernetes master called the deployment controller which makes it happen. It has the capability to change the
deployment midway.