Unit 8
Virtual Machines and Containers:
Virtual machines and Containers are two ways of deploying multiple, isolated
services on a single platform.
Virtual Machine:
It runs on top of an emulating software called the hypervisor which sits between
the hardware and the virtual machine. The hypervisor is the key to enabling
virtualization. It manages the sharing of physical resources into virtual machines.
Each virtual machine runs its guest operating system. They are less agile and have
lower portability than containers.
Container:
It sits on the top of a physical server and its host operating system. They share a
common operating system that requires care and feeding for bug fixes and patches.
They are more agile and have higher portability than virtual machines.
Let’s see the difference between Virtual machines and Containers.
SNo. Virtual Machines(VM) Containers
1 VM is a piece of While a container is
software that allows you software that allows
to install other software different functionalities
inside of it so you control of an application
it virtually as opposed to independently.
installing the software
directly on the computer.
2. Applications running on While applications
a VM system, or running in a container
hypervisor, can run environment share a
different OS. single OS.
3. VM virtualizes the While containers
computer system, virtualize the operating
meaning its hardware. system, or the software
only.
4. VM size is very large, While the size of the
generally in gigabytes. container is very light,
generally a few hundred
megabytes, though it
may vary as per use.
5. VM takes longer to run While containers take far
than containers, the less time to run.
exact time depending on
the underlying hardware.
6. VM uses a lot of system While containers require
memory. very less memory.
7. VM is more secure, as While containers are
the underlying hardware less secure, as the
isn’t shared between virtualization is software-
processes. based, and memory is
shared.
8. VMs are useful when we While containers are
require all of the OS useful when we are
resources to run various required to maximize the
applications. running applications
8. VMs are useful when we While containers are
require all of the OS useful when we are
resources to run various required to maximize the
applications. running applications
using minimal servers.
9. Examples of Type 1 Examples of containers
hypervisors are KVM, are RancherOS,
Xen, and VMware. PhotonOS, and
Virtualbox is a Type 2 Containers by Docker.
hypervisor
What is Docker?
Docker is an open-source containerization platform by which you can pack your
application and all its dependencies into a standardized unit called a container.
Containers are light in weight which makes them portable and they are isolated
from the underlying infrastructure and from each other container. You can run
the docker image as a docker container in any machine where docker is installed
without depending on the operating system.
Why Docker is popular?
Docker gained its popularity due to its impact on the software development and
deployment. The following are the some of the main reasons for docker becoming
popular:
1. Portability: Docker facilitates the developers in packaging their applications
with all dependencies into a single lightweight containers. It facilities in
ensuring the consistent performance across the different computing
environments.
2. Reproducibility: Through encapsulating the applications with their
dependencies within a container it ensures in software setups remaining
consistent across the development, testing and production environments.
3. Efficiency: Docker through its container based architecture it optimizes the
resource utilization. It allows the developers to run the multiple isolated
applications on a single host system.
4. Scalability: Docker’s scalability features facilitated the developers in making
easier of their applications handling at time of workloads increment.
Understanding Docker’s core concepts is crucial, but hands-on experience is what
truly sets you apart. Our DevOps Live Course offers in-depth training on Docker ,
covering everything from the basics to advanced container management
techniques. Learn from industry experts and gain practical experience that will
elevate your skills.
Key Components of Docker
The following are the some of the key components of Docker:
Docker Engine: It is a core part of docker, that handles the creation and
management of containers.
Docker Image: It is a read-only template that is used for creating containers,
containing the application code and dependencies.
Docker Hub: It is a cloud based repository that is used for finding and sharing
the container images.
Dockerfile: It is a script that containing instructions to build a docker image.
Docker Registry : It is a storage distribution system for docker images, where
you can store the images in both public and private modes.
What is a Dockerfile?
The Dockerfile uses DSL (Domain Specific Language) and contains instructions
for generating a Docker image. Dockerfile will define the processes to quickly
produce an image. While creating your application, you should create a Dockerfile
in order since the Docker daemon runs all of the instructions from top to bottom.
(The Docker daemon, often referred to simply as “Docker,” is a background service
that manages Docker containers on a system.)
It is a text document that contains necessary commands which on execution help
assemble a Docker Image.
Docker image is created using a Dockerfile.
What is Docker Architecture and How Docker Works?
Docker makes use of a client-server architecture. The Docker client talks with the
docker daemon which helps in building, running, and distributing the docker
containers. The Docker client runs with the daemon on the same system or we can
connect the Docker client with the Docker daemon remotely. With the help of
REST API over a UNIX socket or a network, the docker client and daemon interact
with each other. To know more about working of docker refer to the Architecture
of Docker .
What is Docker Image?
It is a file, comprised of multiple layers, used to execute code in a Docker container.
They are a set of instructions used to create docker containers. Docker Image is an
executable package of software that includes everything needed to run an
application. This image informs how a container should instantiate, determining
which software components will run and how. Docker Container is a virtual
environment that bundles application code with all the dependencies required to
run the application. The application runs quickly and reliably from one computing
environment to another.
What is Docker Container?
Docker container is a runtime instance of an image. Allows developers to package
applications with all parts needed such as libraries and other dependencies. Docker
Containers are runtime instances of Docker images. Containers contain the whole
kit required for an application, so the application can be run in an isolated way. For
eg.- Suppose there is an image of Ubuntu OS with NGINX SERVER when this
image is run with the docker run command, then a container will be created and
NGINX SERVER will be running on Ubuntu OS.
What is Docker Hub?
Docker Hub is a repository service and it is a cloud-based service where people
push their Docker Container Images and also pull the Docker Container Images
from the Docker Hub anytime or anywhere via the internet. Generally it makes it
easy to find and reuse images. It provides features such as you can push your
images as private or public registry where you can store and share Docker images.
Mainly DevOps team uses the Docker Hub. It is an open-source tool and freely
available for all operating systems. It is like storage where we store the images and
pull the images when it is required. When a person wants to push/pull images from
the Docker Hub they must have a basic knowledge of Docker. Let us discuss the
requirements of the Docker tool.
What is Docker Compose?
Docker Compose will execute a YAML-based multi-container application. The
YAML file consists of all configurations needed to deploy containers Docker
Compose , which is integrated with Docker Swarm , and provides directions for
building and deploying containers. With Docker Compose, each container is
constructed to run on a single host.
How to Download Docker Desktop?
Docker Desktop provides GUI to work on docker containers, docker images and
docker networks. Docker desktop provides and separate environment which
contains Docker Engine, Docker CLI, Docker Compose, Kubernetes, and other
tools which are needed to build, ship and run the applications in the form of
containers which makes it more user friendly. To know more how to install docker
desktop refer to Docker Desktop Sample Image.
Docker Commands
Through introducing the essential docker commands, docker became a powerful
software in streamlining the container management process. It helps in ensuring a
seamless development and deployment workflows. The following are the some of
docker commands that are used commonly:
Docker Run: It used for launching the containers from images, with specifying
the runtime options and commands.
Docker Pull: It fetches the container images from the container registry like
Docker Hub to the local machine.
Docker ps : It helps in displaying the running containers along with their
important information like container ID, image used and status.
Docker Stop : It helps in halting the running containers gracefully shutting
down the processes within them.
Docker Start: It helps in restarting the stopped containers, resuming their
operations from the previous state.
Docker Login: It helps to login in to the docker registry enabling the access to
private repositories.
Docker Engine
The software that hosts the containers is named Docker Engine. Docker Engine is
a client-server based application. The docker engine has 3 main components:
1. Server: It is responsible for creating and managing Docker images, containers,
networks, and volumes on the Docker. It is referred to as a daemon process.
2. REST API : It specifies how the applications can interact with the Server and
instructs it what to do.
3. Client: The Client is a docker command-line interface (CLI), that allows us to
interact with Docker using the docker commands.
Why to use Docker?
Docker can be used to pack the application and its dependencies which makes it
lightweight and easy to ship the code faster with more reliability. Docker make its
very simple to run the application in the production environment docker container
can be platform independent if the docker engine is installed in the machine.
Resource Efficiency : Docker helps in maximizing the resource utilization by
running the multiple containers on a single host. It helps in reducing the
infrastructure costs and improves the efficiency.
Version Control: It simples the versioning for the applications and their
dependencies ensuring the consistency and making easier of collaboration
across the teams.
Microservices Agility: It enables the adoption of microservices architecture,
promoting the scalability, flexibility and fault isolation agile application
development.
Features of Docker
Docker is one of the most popular open-source sets of platforms for developing and
automating the deployment of applications. It deploys applications into containers
and enables us to separate our applications from infrastructure. It is designed to
provide a lightweight and fast environment in which to run our code as well as an
efficient workflow to get that code from our laptop to our test environment and then
into production.
Architecture of Docker
Features of Docker:
Open-source platform
An Easy, lightweight, and consistent way of delivery of applications
Fast and efficient development life cycle.
Segregation of duties
Service-oriented architecture
Security
Scalability
Reduction in size
Image management
Networking
Volume management
Open-Source Platform:
One of the most important aspects of an open-source platform is the ability to choose
which technology to use to complete a task. If a user needs a lightweight, clean
environment for testing, the Docker engine can be useful for lone developers. Docker
Community Edition (docker-ce) is a great way to get started with containers if
Docker is already installed on your system and everyone around you is familiar with
the Docker toolchain.
Easy Way of Delivery of Applications:
It is one of the most significant Docker features that allows you to rapidly and simply
set up the system. Because of this functionality, codes may be input quickly and
easily. Because Docker is utilized in a number of places, the infrastructure is not
related to the application environment.
Docker containers use a shared operating system and only include the necessary
dependencies, making them much smaller and faster to start than traditional virtual
machines. This makes them ideal for deploying applications in various
environments, as they can be easily moved between servers, cloud platforms, and
local development environments.
Fast and Efficient Development Life Cycle:
Docker seeks to shorten the time between writing code and having it tested,
deployed, and used. Its goal is to make your apps portable, simple to construct, and
simple to collaborate on.
Segregation of Duties:
Docker is intended to improve consistency by ensuring that the environment in
which your developers write code is consistent with the environments in which your
applications are deployed. This reduces the possibility of “worked in development,
now an ops issue.”
Service-Oriented Architecture:
Docker also supports service-oriented and microservice architectures.
Docker suggests that each container runs only one application or process. This
encourages the use of a distributed application model in which an application or
service is represented by a collection of interconnected containers. This greatly
simplifies the distribution, scaling, debugging, and inspection of your applications.
Isolation and security:
The Security Management feature of Docker saves secrets into the swarm itself.
Docker containers provide a high level of isolation between different applications,
preventing them from interacting with or affecting each other. This makes them a
secure and stable platform for running multiple applications on a single host.
Scalability:
The platform is easily scalable as Docker containers are lightweight. The portability
of Docker also makes it simple to dynamically manage workloads, scaling up or
down apps and services as business demands in near real-time. Docker provides a
simple and intuitive command-line interface that makes it easy to create, manage,
and deploy containers. It also offers a wide range of tools and integrations for
different development environments, making it easy to incorporate into existing
workflows.
Reduction in size:
Docker offers a great degree of capacity to minimize development size. The rationale
for this is that it may deliver a reduced operating system footprint via containers.
Image management:
Docker uses images to store the necessary files and dependencies needed to run
applications. These images are created using a Dockerfile, which is a set of
instructions that tells Docker how to build the image. Developers can use these
images to create new containers or update existing ones. Docker also has a registry
called Docker Hub, which is a central repository for storing and sharing images.
Networking:
Docker allows developers to easily connect containers and services using its built-in
networking capabilities. It supports the creation of virtual networks and allows
developers to specify which containers can communicate with each other. This
makes it easy to set up and manage complex microservices architectures.
Volume management:
Docker provides a volume management system that allows developers to persist data
generated by containers. This is useful for applications that require a database or
other data storage. Docker volumes are stored on the host system and can be shared
between containers.
Advantages & disadvantages of Dockers:
Docker Pros Docker Cons
Cross-platform consistency: Compatibility across Outdated documentation: Docker’s extensive
a range of systems and environments makes documentation doesn’t always keep pace with
developers’ jobs easier. platform updates.
Serverless storage: Docker containers are cloud- Steep learning curve: Developers transitioning
based and don’t require tons of active memory to from other infrastructure might find Docker easy
run reliably. to begin but hard to master.
High-speed deployment: Eliminating redundant Security issues: The lack of segmentation means
installations and configurations makes deployment that multiple containers can be vulnerable to host
fast and easy. system attacks.
Flexibility and scalability: Developers can use Limited orchestration: It can be difficult to
any programming language and scale container effectively manage multiple containers at once
resources up and down as needed. without orchestration capabilities.
Introduction to Kubernetes (K8S):
Kubernetes is an open-source platform that manages Docker containers in the form
of a cluster. Along with the automated deployment and scaling of containers, it
provides healing by automatically restarting failed containers and rescheduling them
when their hosts die. This capability improves the application’s availability.
What is Kubernetes (k8s)?
Kubernetes is an open-source Container Management tool that automates container
deployment, container scaling, descaling, and container load balancing (also called
a container orchestration tool). It is written in Golang and has a vast community
because it was first developed by Google and later donated to CNCF (Cloud Native
Computing Foundation). Kubernetes can group ‘n’ number of containers into one
logical unit for managing and deploying them easily. It works brilliantly with all
cloud vendors i.e. public, hybrid, and on-premises.
Benefits of Using Kubernetes
1. Automated deployment and management
If you are using Kubernetes for deploying the application then no need for manual
intervention kubernetes will take care of everything like automating the
deployment, scaling, and containerizing the application.
Kubernetes will reduce the errors that can be made by humans which makes the
deployment more effective.
2. Scalability
You can scale the application containers depending on the incoming traffic
Kubernetes offers Horizontal pod scaling the pods will be scaled automatically
depending on the load.
3. High availability
You can achieve high availability for your application with the help of
Kubernetes and also it will reduce the latency issues for the end users.
4. Cost-effectiveness
If there is unnecessary use of infrastructure the cost will also increase kubernetes
will help you to reduce resource utilization and control the overprovisioning of
infrastructure.
5. Improved developer productivity
Developer can concentrate more on the developing part kubernetes will reduce
the efforts of deploying the application.
Features of Kubernetes
1. Automated Scheduling– Kubernetes provides an advanced scheduler to launch
containers on cluster nodes. It performs resource optimization.
2. Self-Healing Capabilities– It provides rescheduling, replacing, and restarting
the containers that are dead.
3. Automated Rollouts and Rollbacks– It supports rollouts and rollbacks for the
desired state of the containerized application.
4. Horizontal Scaling and Load Balancing– Kubernetes can scale up and scale
down the application as per the requirements.
5. Resource Utilization– Kubernetes provides resource utilization monitoring and
optimization, ensuring containers are using their resources efficiently.
6. Support for multiple clouds and hybrid clouds– Kubernetes can be deployed
on different cloud platforms and run containerized applications across multiple
clouds.
7. Extensibility– Kubernetes is very extensible and can be extended with custom
plugins and controllers.
8. Community Support- Kubernetes has a large and active community with
frequent updates, bug fixes, and new features being added.
Advantages & disadvantages of Kubernetes:
What is DevOps?
DevOps is a transformative culture and practice that unites software
development (Dev) and IT operations (Ops) teams. By fostering collaboration
and leveraging automation technologies, DevOps enables faster, more reliable code
deployment to production in an efficient and repeatable manner.
DevOps Model Defined
DevOps is a software development approach that emphasizes collaboration and
communication between development (Dev) and operations (Ops) teams. It aims
to shorten the software development lifecycle and improve the quality and
reliability of software releases.
Delivery Pipeline
The pipeline represents the different stages that software goes through before it is
released to production. These stages might typically include:
Build: The stage where the software code is compiled and packaged into a
deployable unit.
Test: The stage where the software is rigorously tested to ensure it functions as
expected and identifies any bugs.
Release: The stage where the software is deployed to production for end users.
Feedback Loop
The loop indicates that information and learnings from the production environment
are fed back into the earlier stages of the pipeline. This feedback can be used to
improve the software development process and future releases.
How DevOps Works?
DevOps will remove the “siloed” conditions between the development team and
operations team. In many cases these two teams will work together for the entire
application lifecycle, from development and test to deployment to operations, and
develop a range of skills not limited to a single function.
Teams in charge of security and quality assurance may also integrate more closely
with development and operations over the course of an application’s lifecycle
under various DevOps models. DevSecOps is the term used when security is a top
priority for all members of a DevOps team.
These teams employ procedures to automate labor-intensive, manual processes that
were slow in the past. They employ a technological stack and tooling that facilitate
the swift and dependable operation and evolution of apps. A team’s velocity is
further increased by these technologies, which also assist engineers in
independently completing activities (such provisioning infrastructure or delivering
code) that ordinarily would have needed assistance from other teams.
Why DevOps Matters?
The world has undergone a massive transformation thanks to software and the
Internet. It’s not just about businesses using software as a tool anymore; it’s about
software being at the core of everything they do. Whether it’s interacting with
customers through online platforms or optimizing internal processes like logistics
and operations, software is the driving force behind it all. Just as companies in the
past revolutionized manufacturing with automation, today’s companies need to
revolutionize how they create and deliver software to stay competitive.
Key Features of DevOps:
1. Collaboration and Communication:
o DevOps emphasizes strong collaboration between development (Dev)
and operations (Ops) teams. It breaks down silos and fosters a culture
of shared responsibility for the entire software lifecycle.
2. Continuous Integration (CI):
o CI is the practice of frequently integrating code changes into a shared
repository. This allows developers to detect integration issues early and
improves collaboration between team members.
3. Continuous Delivery/Continuous Deployment (CD):
o Continuous Delivery ensures that code is always in a deployable state,
while Continuous Deployment automates the release of software to
production. This results in faster delivery of new features and bug fixes.
4. Automation:
o Automation of repetitive tasks, such as testing, integration, deployment,
and infrastructure provisioning, is a core principle of DevOps. This
reduces manual errors and speeds up the delivery pipeline.
5. Infrastructure as Code (IaC):
o IaC involves managing and provisioning infrastructure through code
rather than manual processes. It ensures consistency, reduces the risk
of human error, and allows for version-controlled infrastructure.
6. Monitoring and Feedback:
o Continuous monitoring of applications and infrastructure is a key
component of DevOps. Teams can receive real-time feedback, detect
issues early, and make data-driven decisions to improve performance.
7. Version Control:
o DevOps encourages the use of version control systems (such as Git) for
both code and configuration files. This enables teams to manage
changes efficiently, track versions, and collaborate on projects
seamlessly.
8. Microservices Architecture:
o Many DevOps teams use a microservices architecture, where
applications are broken down into smaller, independently deployable
services. This enhances scalability, flexibility, and speed of
development.
9. Testing Automation:
o DevOps promotes the use of automated testing (unit tests, integration
tests, end-to-end tests) to ensure quality and catch issues early in the
development process.
10.Security (DevSecOps):
o Security practices are integrated into the DevOps pipeline, ensuring that
security concerns are addressed at every stage of development and
deployment.
Advantages of DevOps:
1. Faster Time to Market:
o By automating processes, streamlining workflows, and ensuring
continuous integration and delivery, DevOps accelerates the time it
takes to develop, test, and deploy applications.
2. Improved Collaboration and Efficiency:
o The collaboration between development and operations teams fosters a
culture of shared responsibility and mutual respect. This leads to
improved communication, faster problem-solving, and higher
productivity.
3. Higher Quality and Reliability:
o Continuous testing, integration, and monitoring help catch bugs and
performance issues early, improving the overall quality of the software.
Automated testing ensures that only high-quality code is released to
production.
4. Increased Automation and Reduced Manual Errors:
o Automating repetitive tasks like testing, deployment, and infrastructure
management reduces the risk of human error and increases the
consistency of the software lifecycle.
5. Scalability and Flexibility:
o DevOps practices like microservices and IaC allow teams to scale
applications quickly and adapt to changing requirements. Infrastructure
can be provisioned and managed efficiently, even at a large scale.
6. Improved Customer Experience:
o With faster deployment cycles and the ability to quickly address bugs
and feature requests, DevOps results in an improved user experience.
Frequent releases mean customers get new features and bug fixes faster.
7. Cost Efficiency:
o Automation of manual processes, along with better resource utilization,
can lead to cost savings. Additionally, the faster delivery of software
means that teams can quickly adapt to business changes and reduce
wasted resources.
8. Faster Recovery from Failures:
o The rapid feedback loop and continuous monitoring enable teams to
identify and address issues quickly, leading to faster recovery in case
of failures. Additionally, automated rollbacks reduce downtime.
9. Improved Security:
o DevSecOps ensures that security is integrated throughout the
development and deployment pipeline, reducing vulnerabilities and
strengthening the security posture of the organization.
10.Better Risk Management:
o By automating processes, improving testing, and having real-time
monitoring, DevOps helps identify and mitigate risks early. This
proactive approach reduces the likelihood of major failures in
production