KEMBAR78
Module1 Notes Devops | PDF | Cloud Computing | Virtual Machine
0% found this document useful (0 votes)
13 views39 pages

Module1 Notes Devops

dsds

Uploaded by

Charlie
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
13 views39 pages

Module1 Notes Devops

dsds

Uploaded by

Charlie
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 39

MODULE-1

Devops

Introduction to DevOps , What is DevOps? ,History of DevOps ,Dev and Ops ,DevOps
definitions ,DevOps and Software Development Life Cycle ,Why DevOps& Main objectives,
Concepts of Cloud and Virtualization ,History and Evolution of cloud , Cloud computing
concepts , Characteristics and Benefits of Cloud ,Cloud Service models ,IaaS, PaaS and SaaS,
Virtualization , Virtual Machines vs Containers.
Introduction to Devops

DevOps is a collaboration between Development and IT Operations to make software


production and deployment in an automated & repeatable way. DevOps helps to increase the
organization’s speed to deliver software applications and services. The word ‘DevOps’ is a
combination of two words, ‘Development’ and ‘Operations.’
It allows organizations to serve their customers better and compete more strongly in the market.
In simple words, DevOps can be defined as an alignment of development and IT operations
with better communication and collaboration.

DevOps promotes collaboration between Development and Operations team to deploy code to
production faster in an automated & repeatable way.
DevOps helps to increase organization speed to deliver applications and services. It also allows
organizations to serve their customers better and compete more strongly in the market.

DevOps can also be defined as a sequence of development and IT operations with better
communication and collaboration.

DevOps has become one of the most valuable business disciplines for enterprises or
organizations. With the help of DevOps, quality, and speed of the application delivery has
improved to a great extent.

DevOps is nothing but a practice or methodology of making "Developers" and "Operations"


folks work together. DevOps represents a change in the IT culture with a complete focus on
rapid IT service delivery through the adoption of agile practices in the context of a system-
oriented approach.

Why DevOps?

why we need the DevOps over the other methods.

o The operation and development team worked in complete isolation.


o After the design-build, the testing and deployment are performed respectively. That's
why they consumed more time than actual build cycles.
o Without the use of DevOps, the team members are spending a large amount of time on
designing, testing, and deploying instead of building the project.
o Manual code deployment leads to human errors in production.
o Coding and operation teams have their separate timelines and are not in synch, causing
further delays.

DevOps History

o In 2009, the first conference named DevOpsdays was held in Ghent Belgium. Belgian
consultant and Patrick Debois founded the conference.
o In 2012, the state of DevOps report was launched and conceived by Alanna Brown at
Puppet.
o In 2014, the annual State of DevOps report was published by Nicole Forsgren, Jez
Humble, Gene Kim, and others. They found DevOps adoption was accelerating in 2014
also.
o In 2015, Nicole Forsgren, Gene Kim, and Jez Humble founded DORA (DevOps
Research and Assignment).
o In 2017, Nicole Forsgren, Gene Kim, and Jez Humble published "Accelerate: Building
and Scaling High Performing Technology Organizations

Difference between Dev and ops:

The Development team works on code which is then sent to the testing team for validation
against requirements.

Operation team comes in toward the end of the process, where handover of release is given.
DevOps aims to break these silos enabling better collaboration and performance.

Devops and software development lifecycle:


Before DevOps, software applications were developed with either the waterfall model or the
AGILE development model:

● The waterfall or sequential model was a pioneering approach in the Software


Development Life Cycle (SDLC). With this model, software development becomes a
linear process where different phases and tasks are positioned successively.
● AGILE software development, on the other hand, involved the use of various
approaches and the collaboration of multiple teams in SDLC.

DevOps Services came into play by effectively serving the purpose of reducing the time
involved in SDLC for prompt deliveries and securing the continuous production of high-quality,
foolproof software applications.

DevOps is primarily implemented in application development for e-commerce websites, cloud-


native applications, and other large distributed platforms. It consists of multiple phases that
collectively become the DevOps lifecycle.
1. Continuous Development

This phase involves the planning and coding of the software. The vision of the project is
decided during the planning phase. And the developers begin developing the code for the
application. There are no DevOps tools that are required for planning, but there are several tools
for maintaining the code.

2. Continuous Integration

This stage is the heart of the entire DevOps lifecycle. It is a software development practice in
which the developers require to commit changes to the source code more frequently. This may
be on a daily or weekly basis. Then every commit is built, and this allows early detection of
problems if they are present. Building code is not only involved compilation, but it also
includes unit testing, integration testing, code review, and packaging.

The code supporting new functionality is continuously integrated with the existing code.
Therefore, there is continuous development of software. The updated code needs to be
integrated continuously and smoothly with the systems to reflect changes to the end-users.

Jenkins is a popular tool used in this phase. Whenever there is a change in the Git repository,
then Jenkins fetches the updated code and prepares a build of that code, which is an executable
file in the form of war or jar. Then this build is forwarded to the test server or the production
server.
3. Continuous Testing

This phase, where the developed software is continuously testing for bugs. For constant testing,
automation testing tools such as TestNG, JUnit, Selenium, etc are used. These tools allow QAs
to test multiple code-bases thoroughly in parallel to ensure that there is no flaw in the
functionality. In this phase, Docker Containers can be used for simulating the test environment.

Selenium does the automation testing, and TestNG generates the reports. This entire testing
phase can automate with the help of a Continuous Integration tool called Jenkins.

Automation testing saves a lot of time and effort for executing the tests instead of doing this
manually. Apart from that, report generation is a big plus. The task of evaluating the test cases
that failed in a test suite gets simpler.

4.Continuous Monitoring

Monitoring is a phase that involves all the operational factors of the entire DevOps process,
where important information about the use of the software is recorded and carefully processed
to find out trends and identify problem areas. Usually, the monitoring is integrated within the
operational capabilities of the software application.

1. Infrastructure Monitoring - Tools and processes for monitoring the data centers,
networks, hardware, and software needed to deliver products and services.
2. Application Monitoring - Tools and processes for monitoring the health and
performance of released applications in a production environment.
3. Network Monitoring - Tools and processes for monitoring network activity and
components, such as servers, firewalls, routers, and switches, as well as detecting
security threats across the network.

Continuous monitoring Tools

1. Akamai mPulse is a Real User Monitoring (RUM) tool that allows DevOps
teams to collect and analyze experience and behavior data from users who visit
their website or application.
2. AppDynamics helps identify and manage the working of applications in the cloud
environment and in the servers.
3. Dynatrace provides a single platform with the ability to monitor the entire
DevOps environment and technology stack. DevOps teams can use Dynatrace to
gain visibility into web and mobile applications, transactions and services,
databases, hosts, and network infrastructure.

5. Continuous Feedback

The application development is consistently improved by analyzing the results from the
operations of the software. This is carried out by placing the critical phase of constant feedback
between the operations and the development of the next version of the current software
application.
Best practices to achieve continuous feedback in devops environments
1.Integrate real-time communication
2.Focus messaging to cut through noise
3.Don’t totally abandon manual messages
4.Emphasize system monitoring
5.Expand beyond traditional feedback
6.Measure Feedback success
6.Continuous Deployment

In this phase, the code is deployed to the production servers. Also, it is essential to ensure that
the code is correctly used on all the servers.

The new code is deployed continuously, and configuration management tools play an essential
role in executing tasks frequently and quickly. Here are some popular tools which are used in
this phase, such as Chef, Puppet, Ansible, and SaltStack.

Containerization tools are also playing an essential role in the deployment


phase. Vagrant and Docker are popular tools that are used for this purpose. These tools help to
produce consistency across development, staging, testing, and production environment. They
also help in scaling up and scaling down instances softly.

7. Continuous Operations

All DevOps operations are based on the continuity with complete automation of the release
process and allow the organization to accelerate the overall time to market continuingly.

It is clear from the discussion that continuity is the critical factor in the DevOps in removing
steps that often distract the development, take it longer to detect issues and produce a better
version of the product after several months. With DevOps, we can make any software product
more efficient and increase the overall count of interested customers in your product.

Benefits of Devops:

Devops is important because it’s a software development and operations approach that enables
faster development of new products and easier maintenance of existing deployments

Benefits:

1.Maximizes Efficiency and Automation

2.Optimizes the entire business

3. Improves Speed and Stability of Software Development and Deployment

4.Gets You to Focus on What Matters Most: People

Devops Objectives:

DevOps is an umbrella concept which deals with anything to smooth out the process from
development to deployment into production.

1.Introduce Code Review System

2.Automate Build

3.Automate Testing
4.Automate Deployment

5.Automate Monitoring

6.Automate Issue Tracking

7.Automate Feedbacks

These objects can be achieved by setting up a Continuous Integration pipeline and a Continuous
Deployment/Delivery process. Post delivery, a process for Continuous Monitoring is set up.

Cloud computing

Cloud computing, or what is simply referred to as the cloud, can be defined as an Internet-based
computing that largely offers on-demand access to computing resources. These resources
comprise of many things, such as application software, computing resources, servers and data
centers etc.

Cloud service providers usually adopt a ‘pay-as-you-go’ model, something that allows
companies to scale their costs as per need. It allows businesses to bypass infrastructural setup
costs, which was inevitable prior to the advent of the cloud.

The evolution of cloud computing can be bifurcated into three basic phases:

1. The Idea Phase- This phase incepted in the early 1960s with the emergence of utility and
grid computing and lasted till pre-internet era. Joseph Carl Robnett Licklider was the founder
of cloud computing.

2. The Pre-cloud Phase- The pre-cloud phase originated in the 1999 and extended to 2006. In
this phase internet was used as the mechanism to provide Application as Service.

3. The Cloud Phase- The much talked about real cloud phase started in the year 2007 when the
classification of IaaS, PaaS, and SaaS got formalized. The history of cloud computing has
witnessed some very interesting breakthroughs launched by some of the leading computer/web
organizations of the world.
Essential Concepts of Cloud

Abstraction: Cloud computing abstracts the details of system implementation from users and
developers. Applications run on physical systems that aren’t specified, data is stored in
locations that are unknown, administration of systems is outsourced to others, and access by
users is ubiquitous. It is used to reduce cost and complexity, which in turn, simplifies
operations.

Virtualization: Cloud computing virtualizes systems by pooling and sharing resources.


Systems and storage can be provisioned as needed from a centralized infrastructure, costs are
assessed on a metered basis, multi-tenancy is enabled, and resources are scalable with agility.

● When using cloud computing, we are accessing pooled resources using a technique
called virtualization, which allows creating a virtual version of computer resources with a
goal of centralizing administrative tasks. Virtualization has become an indispensable tool
for almost every cloud; it has become an important technique for establishing modern
cloud computing services.
Characteristics of cloud computing
● Agility
● High Availability and reliability
● High scalability
● Multi sharing
● Device and location independence
● Maintenance
● Low cost
● Services in the pay per use model

Cloud Types

Cloud computing is divided in to two distinct sets of models:


Deployment models: This refers to the location and management of the cloud’s infrastructure.

Service models: This consists of the particular types of services that you can access on a cloud
computing platform

Deployment models
• There are four primary cloud deployment models :

▪ Public Cloud

▪ Private Cloud

▪ Community Cloud

▪ Hybrid Cloud

Public Cloud

• Public cloud definition

▪ The cloud infrastructure is made available to the general public or a large


industry group and is owned by an organization selling cloud services.
▪ Also known as external cloud or multi-tenant cloud, this model essentially
represents a cloud environment that is openly accessible.
▪ Basic characteristics :

• Homogeneous infrastructure

• Common policies

• Shared resources and multi-tenant

• Leased or rented infrastructure


• Economies of scale

Advantages

● Public cloud is owned at a lower cost than the private and hybrid cloud.

● Public cloud is highly scalable as per the requirement of computing resources.

● It is accessible by the general public, so there is no limit to the number of users

Private Cloud

Private cloud definition

▪ The cloud infrastructure is operated solely for an organization. It may be


managed by the organization or a third party and may exist on premise or
off premise.
▪ Also referred to as internal cloud or on-premise cloud, a private cloud
intentionally limits access to its resources to service consumers that belong
to the same organization that owns the cloud.
▪ Basic characteristics :

• Heterogeneous infrastructure

• Customized and tailored policies


• Dedicated resources

• In-house infrastructure

• End-to-end control

Advantages

● Private cloud provides a high level of security and privacy to the users.

● Private cloud offers better performance with improved speed and space capacity
Community Cloud

• Community cloud definition

The cloud infrastructure is shared by several organizations and supports a specific


community that has shared concerns (e.g., mission, security requirements, policy, and
compliance considerations).

Characteristics

● Community cloud allows systems and services to be accessible by a group of several


organizations to share the information between the organization and a specific
community

● Community cloud is cost-effective because the whole cloud is being shared by several
organizations or communities.

Community cloud is suitable for organizations that want to have a collaborative cloud

with more security features than the public cloud


Hybrid Cloud

• Hybrid cloud definition

▪ The cloud infrastructure is a composition of two or more clouds (private,


community, or public) that remain unique entities but are bound together by
standardized or proprietary technology that enables data and application
portability(e.g., cloud bursting for load-balancing between clouds).

● Hybrid cloud is suitable for organizations that require more security than the public
cloud.

● Hybrid cloud helps you to deliver new products and services more quickly.

Public vs. Private

Public Cloud Private Cloud

Infrastructure Homogeneous Heterogeneous

Policy Model Common defined Customized & Tailored


Resource Model Shared & Multi-tenant Dedicated

Cost Model Operational expenditure Capital expenditure

Economy Model Large economy of scale End-to-end control

Service Models

1. Infrastructure as a Service

2. Platform as a Service

3. Software as a Service
Three service types have been universally accepted:
Infrastructure as a Service: IaaS provides virtual machines, virtual storage, virtual
infrastructure, and other hardware assets as resources that clients can provision.
The IaaS service provider manages all the infrastructure, while the client is
responsible for all other aspects of the deployment. This can include the operating
system, applications, and user interactions with the system.
Characteristics of IaaS
● Resources are available as a service
● Services are highly scalable
● Dynamic and flexible
● GUI and API-based access
● Automated administrative tasks
Eg: Amazon Web Services (AWS), Microsoft Azure, Google Compute Engine
(GCE), Rackspace, and Cisco Metacloud.
Platform as a Service: PaaS provides virtual machines, operating systems,
applications, services, development frameworks, transactions, and control
structures.
The client can deploy its applications on the cloud infrastructure or use
applications that were programmed using languages and tools that are supported by the
PaaS service provider.
The service provider manages the cloud infrastructure, the operating systems, and
the enabling software. The client is responsible for installing and managing the
application that it is deploying.
Characteristics of Paas
● Accessible to various users via the same development application.
● Integrates with web services and databases.
● Builds on virtualization technology, so resources can easily be scaled up or down as
per the organization's need.
● Support multiple languages and frameworks.
● Provides an ability to "Auto-scale".
Eg: AWS Elastic Beanstalk, Windows Azure, Heroku, Force.com, Google App
Engine, Apache Stratos, Magento Commerce Cloud, and OpenShift.
Software as a Service: SaaS is a complete operating environment with applications,
management, and the user interface.
In the SaaS model, the application is provided to the client through a thin client
interface (a browser, usually), and the customer’s responsibility begins and ends with
entering and managing its data and user interaction. Everything from the application
down to the infrastructure is the vendor’s responsibility
Characteristics of Saas
● Managed from a central location
● Hosted on a remote server
● Accessible over the internet
● Users are not responsible for hardware and software updates. Updates are applied
automatically.
● The services are purchased on the pay-as-per-use basis
Eg: BigCommerce, Google Apps, Salesforce, Dropbox, ZenDesk, Cisco WebEx,
ZenDesk, Slack, and GoToMeeting
Examples Of Service providers

Examples of IaaS service providers include:

● Amazon Elastic Compute Cloud (EC2)

● Eucalyptus

● GoGrid

● FlexiScale

● Linode

● RackSpace Cloud

● Terremark

Examples of PaaS services providers are:

● Force.com

● GoGrid CloudCenter

● Google AppEngine

● Windows Azure Platform

Examples of SaaS cloud service providers are:


● GoogleApps

● Oracle On Demand

● SalesForce.com

● SQL Azure

The three different service models taken together have come to be known as the SPI
model of cloud computing
The cloud reference model

The representation of cloud computing service model in terms of a hardware or


software stack or called as cloud reference model. The cloud reference model is a
conceptual model that characterizes and standardizes the functions of a cloud computing
environment. It provides a fundamental reference point for the development of cloud
computing.
Standards bodies define the cloud reference models and then vendors map their
services to these models. The National Institute of Standards and Technology (NIST), a
US Government body, defines the standard protocol for cloud computing providers.
Vendors then develop their cloud platform while following the defined standard
guidelines and start their operational engagement with enterprise business systems.
NIST took an early leadership role in standardizing the definitions around cloud
computing.

This happened as cloud technology was making inroads into the U.S. federal government.

Leading cloud service providers map their services to the NIST reference model.
IBM, Microsoft, Oracle, and Amazon are leading companies in the market which provide
cloud service that comply with the NIST reference model. The reference model:

● Describes the domain and key concepts.

● Provides a shared vision, understanding, and taxonomy.

● Reduces complexity to enhance the development of new products.

● Provides a guide for interoperability and standards.

● Provides a model for functions and services of cloud implementations.

● Defines best practices.

The NIST cloud computing reference model identifies the major actors, their
activities and functions in cloud computing. Figure, depicts the NIST high-level
model or architecture, which defines the requirements, uses, characteristics, and
standards of cloud computing:

Benefits of Cloud Computing:

⮚ On-demand Self Service: A consumer can unilaterally provision computing


capabilities, such as server time and network storage, as needed automatically
without requiring human interaction with each service provider.

⮚ Broad Network Access: Capabilities are available over the network and accessed
through standard mechanisms that promote use by heterogeneous thin or thick
client platforms (e.g., mobile phones, tablets, laptops and workstations).

⮚ Resources Pooling: The provider's computing resources are pooled to serve


multiple consumers with different physical and virtual resources dynamically
assigned and reassigned according to consumer demand.

⮚ Rapid Elasticity: Capabilities can be elastically provisioned and released, in some


cases automatically. To the consumer, the capabilities available for provisioning
often appear to be unlimited and can be appropriated in any quantity at any time.

⮚ Measured service: Resource usage can be monitored, controlled and reported,


providing transparency for the provider and consumer.
Advantages & Disadvantages

Advantages:

⮚ Usability: All cloud storage services have desktop folders for Mac’s and PC’s.
This allows users to drag and drop files between the cloud storage and their local
storage.

⮚ Bandwidth: You can avoid emailing files to individuals and instead send a web
link to recipients through your email.

⮚ Accessibility: Stored files can be accessed from anywhere via Internet connection.

⮚ Disaster Recovery: It is highly recommended that businesses have an emergency


backup plan ready in the case of an emergency. Cloud storage can be used as a
back‐ up plan by businesses by providing a second copy of important files. These
files are stored at a remote location and can be accessed through an internet
connection.

⮚ Cost Savings: Businesses and organizations can often reduce annual operating
costs by using cloud storage; cloud storage costs about 3 cents per gigabyte to
store data internally. Users can see additional cost savings because it does not
require internal power to store information remotely.

Disadvantages:

⮚ Usability: Be careful when using drag/drop to move a document into the cloud
storage folder. This will permanently move your document from its original folder
to the cloud storage location.

⮚ Bandwidth: Several cloud storage services have a specific bandwidth allowance.


If an organization surpasses the given allowance, the additional charges could be
significant.

⮚ Accessibility: If you have no internet connection, you have no access to your data.

⮚ Data Security: There are concerns with the safety and privacy of important data
stored remotely. The possibility of private data commingling with other
organizations makes some businesses uneasy.

⮚ Software: If you want to be able to manipulate your files locally through multiple
devices, you’ll need to download the service on all devices.

Types of Virtualization:
1. Hardware Virtualization.
2. Operating system Virtualization.

3. Server Virtualization.

4. Storage Virtualization.

1) Hardware Virtualization:

When the virtual machine software or virtual machine manager (VMM) is directly installed on the
hardware system is known as hardware virtualization.

The main job of hypervisor is to control and monitoring the processor, memory and other hardware
resources.

After virtualization of hardware system we can install different operating system on it and run different
applications on those OS.

2) Operating System Virtualization:

When the virtual machine software or virtual machine manager (VMM) is installed on the Host
operating system instead of directly on the hardware system is known as operating system
virtualization.

Usage:

Operating System Virtualization is mainly used for testing the applications on different platforms of OS.

3) Server Virtualization:

When the virtual machine software or virtual machine manager (VMM) is directly installed on the
Server system is known as server virtualization.

Usage:
Server virtualization is done because a single physical server can be divided into multiple servers on the
demand basis and for balancing the load.

4) Storage Virtualization:

Storage virtualization is the process of grouping the physical storage from multiple network storage
devices so that it looks like a single storage device.

Storage virtualization is also implemented by using software applications.

Some terminologies associated with Virtualization

1. Hypervisor: It is an operating system, performing on the actual hardware, the virtual


counterpart is a subpart of this operating system in the form of a running process.
Hypervisors are observed as Domain 0 or Dom0.
2. Virtual Machine (VM): It is a virtual computer, executing underneath a hypervisor.
3. Container: Some light-weighted VMs that are subpart of the same operating system
instance as its hypervisor are known as containers. They are a group of processes that
runs along with their corresponding namespace for process identifiers.
4. Virtualization Software: Either be a piece of a software application package or an
operating system or a specific version of that operating system, this is the software
that assists in deploying the virtualization on any computer device.
5. Virtual Network: It is a logically separated network inside the servers that could be
expanded across multiple servers
Hypervisor
● hypervisors are commonly used to allocate physical hardware resources to virtual
machines, which are known as “guests” on the host machine.
● We can use a hypervisor to run processes and operating systems on virtual machines,
totally separate from your main system.
Virtual machine
● A Virtual Machine (VM) is a compute resource that uses software instead of a
physical computer to run programs and deploy apps.
● One or more virtual “guest” machines run on a physical “host” machine. ... This
means that, for example, a virtual MacOS virtual machine can run on a physical PC.
VM and how does it work?
A VM provides an isolated environment for running its own OS and applications independently
from the underlying host system or from other VMs on that host. The VM's OS is commonly
referred to as the guest OS, and it can be the same as or different from the host OS or the other
VMs. In this way, a single computer can host multiple VMs, all running different OSes and
applications, without affecting or interfering with each other. The VM is still dependent on the
host's physical resources, but those resources are virtualized and distributed across the VMs and
can be reassigned as necessary, making it possible to run different environments
simultaneously, as well as accommodate fluctuating workloads.

Organisations use VM for several reasons:


VMs help organizations consolidate servers and better utilize hardware
resources.

● VMs provide isolated environments, making it possible to run different types of OSes and
applications on a single server

● VMs make it easy to scale applications and accommodate fluctuating workloads, which is
one reason virtualization plays such a key role in cloud computing and systems such as
hyper-converged infrastructure (HCI).

● Organizations also turn to VMs because of the extra layer of security they provide against
potential threats

● VMs make it easier to manage multiple environments running different OSes


Container
A container is a standard unit of software that packages up code and all its dependencies so
the application runs quickly and reliably from one computing environment to another.
A Docker container image is a lightweight, standalone, executable package of software that
includes everything needed to run an application: code, runtime, system tools, system
libraries and settings.
● Containers are an abstraction at the app layer that packages code and dependencies
together.
● Multiple containers can run on the same machine and share the OS kernel with other
containers, each running as isolated processes in user space.
● Containers take up less space than VMs (container images are typically tens of MBs
in size), can handle more applications and require fewer VMs and Operating systems.
Containers are a streamlined way to build, test, deploy, and redeploy applications on
multiple environments from a developer’s local laptop to an on-premises data center and
even the cloud.
Benefits of containers include:
● Less overhead
Containers require less system resources than traditional or hardware virtual machine
environments because they don’t include operating system images.
● Increased portability
Applications running in containers can be deployed easily to multiple different
operating systems and hardware platforms.
● More consistent operation
DevOps teams know applications in containers will run the same, regardless of where
they are deployed.
● Greater efficiency
Containers allow applications to be more rapidly deployed, patched, or scaled.
● Better application development
Containers support agile and DevOps efforts to accelerate development, test, and
production cycles.
Virtualization software
This is the software that assists in deploying the virtualization on any computer device.
Some of the virtualization softwares are
● #1) SolarWinds Virtualization Manager
● #2) V2 Cloud
● #3) VMware Fusion
● #4) Parallels Desktop
● #5) Oracle VM Virtual Box
● #6) VMware Workstation
● #7) QEMU
● #8) Windows Virtual PC
● #9) Microsoft Hyper-V
● #10) RedHat Virtualization
● #11) Veertu for Mac
● #12) Boot Camp
Virtual Network:
● vSwitch Software: Virtualization software on host servers that allows you to set up
and configure a virtual network.
● Virtual network adapter: Creates a gateway between networks.
● Physical network: Required as a host for the virtual network infrastructure.
● Virtual machines and devices: Instruments that connect to the network and allow
various functionality.
● Servers: Part of the network host infrastructure.
● Firewalls and security: Designed for monitoring and stopping security threats

Virtual machine vs containers


Virtual machines containers
1.VM is piece of software that allows you 1.While a container is a software that
to install other software inside of it so you allows different functionalities of an
basically control it virtually as opposed to application independently.
installing the software directly on the
computer.
2.Applications running on VM system can 2.While applications running in a
run different OS. container environment share a single OS.
3.VM virtualizes the computer system. 3.While containers virtualize the operating
system only.
4.VM is more secure 4.While containers are less secure.
5.VM’s are useful when we require all of 5.While containers are useful when we are
OS resources to run various applications. required to maximise the running
applications using minimal servers.
6.Examples of VM are: KVM, Xen, 6.While examples of containers are:
VMware. RancherOS, PhotonOS, Containers by
Docker.

Cloud vs virtualization

You might also like