Virtualization
Introduction
• Creating a virtual (rather than actual) version of something, such as a server, desktop, storage
device, operating system, or network resources, is known as virtualization.
• In other terms, virtualization is a technique that enables several consumers and organisations to
share a single physical instance of a resource or an application. It accomplishes this by giving a
physical storage a logical name and supplying a pointer to that physical resource when needed.
• It is the process of creating a virtual version of something like computer hardware.
• It was initially developed during the mainframe era.
•It involves using specialized software to create a virtual or software-created version of a
computing resource rather than the actual version of the same resource.
•With the help of Virtualization, multiple operating systems and applications can run on the same
machine and its same hardware at the same time, increasing the utilization and flexibility of
hardware.
• In other words, one of the main cost-effective, hardware-reducing, and energy-saving techniques used by cloud providers
is Virtualization.
• Moreover, virtualization technologies provide a virtual environment for not only executing applications but also for
storage, memory, and networking.
• It is a technique which allows to share single physical instance of an application or resource among multiple org. or
customers.
• All virtual resources will work independently.
• Concept behind Virtualization
• Creation of a virtual machine over existing operating system and hardware is known as Hardware Virtualization. A Virtual
machine provides an environment that is logically separated from the underlying hardware.
• Host Machine: The machine on which the virtual machine is going to be built is known as Host Machine.
• Guest Machine: The virtual machine is referred to as a Guest Machine.
• Here is a list of terms that are associated with virtualization-
1. Hypervisor- It is the OS that runs on actual hardware and the Virtual counterpart is a part of this
OS as a running process. Hypervisors are often seen as Domain 0 or Dom0.
2. Virtual Machine (VM)- It is a virtual computer that runs under a hypervisor.
3. Container- These are light-weight VMs that are part of the same OS instance as its hypervisor.
So, containers are nothing but a group of processes that are running with their respective
namespace for process identifiers.
4. Virtualization Software- It is a software that aids in implementing virtualization on any
computer. It can either be a part of a software application package or an OS or a special variant
of that OS.
5. Virtual Network- Virtual Network is a logically separate network within servers that can be
extended to other servers or across multiple servers.
Types of Virtualization
1. Network Virtualization
2. Application Virtualization
3. Storage Virtualization
4. Server Virtualization
5. Desktop Virtualization
6. Data Virtualization
Network Virtualization
•The ability to run multiple virtual networks with each having a separate control and data
plan. It co-exists together on top of one physical network.
•It can be managed by individual parties that are potentially confidential to each other.
•Network virtualization provides a facility to create and provision virtual networks, logical
switches, routers, firewalls, load balancers, Virtual Private Networks (VPN), and
workload security within days or even weeks.
Application Virtualization
•It is a process of virtualizing the applications that may or may not be on the guest OS which has
been hosted.
•It offers access to an application without requiring the target device to have it installed.
•Application virtualization helps a user to have remote access to an application from a server. The
server stores all personal information and other characteristics of the application but can still
run on a local workstation through the internet.
•An example of this would be a user who needs to run two different versions of the same
software. Technologies that use application virtualization are hosted applications and packaged
applications.
Storage Virtualization
•It can be known as the process wherein you combine the physical storage from different
network storage devices. This makes it look like a single storage device.
•Storage Virtualization concerning Cloud Computing is the grouping of physical storages that are
composed of various network storage devices. The grouping is done in a way that looks like a
single storage unit. With the help of software applications, storage virtualization is used for
backup and recovery processes.
•storage virtualization software maintains smooth operations, consistent performance, and a
continuous suite of advanced functions despite changes, breaks down, and differences in the
underlying equipment.
Server Virtualization
•In case of server virtualization in Cloud Computing, the software is installed directly on the
server system.
•The single physical server can now split into multiple servers depending on the demand it’s
managing and the load that is being processed.
•Server virtualization masks server resources that hold identity and number. To summarize, the
installed software is dividing the physical server into its integral virtual counterparts.
•It is the process of installing the virtual machine manager (VMM) or virtual machine software
directly on the server system. This type of virtualization involves the masking of server
resources. Here, the identity number and processors of the physical server are changed to
create many virtual servers. Therefore, each system can independently run its own operating
system.
Desktop Virtualization
•Desktop virtualization allows the users’ OS to be remotely stored on a server in the data center.
It allows the user to access their desktop virtually, from any location by a different machine.
•Users who want specific operating systems other than Windows Server will need to have a
virtual desktop.
•It is the ability to store the OS on a server, allowing the users to access their desktop virtually
from any location and even from a different machine.
•The main benefits of desktop virtualization are user mobility, portability, and easy management
of software installation, updates, and patches.
Data Virtualization
•This is the kind of virtualization in which the data is collected from various sources and managed
at a single place without knowing more about the technical information like how data is
collected, stored & formatted then arranged that data logically so that its virtual view can be
accessed by its interested people and stakeholders, and users through the various cloud services
remotely.
•It can be used to carry out a wide range of tasks, including data integration, business integration,
service-oriented architecture, and data services.
•Given these wide varieties to use, virtualization is indeed a technology that is making humans
put less effort into their digital work field.
Characteristics
•Increased Security: The ability to control the execution of a guest program in a completely transparent
manner opens new possibilities for delivering a secure, controlled execution environment. All the
operations of the guest programs are generally performed against the virtual machine, which then
translates and applies them to the host programs.
•Managed Execution: In particular, sharing, aggregation, emulation, and isolation are the most relevant
features.
•Sharing: Virtualization allows the creation of a separate computing environment within the same host.
•Aggregation: It is possible to share physical resources among several guests, but virtualization also allows
aggregation, which is the opposite process.
• Portability – The concept of portability applies in different ways according to the specific type of
virtualization considered.
In the case of a hardware virtualization solution, the guest is packaged into a virtual image that, in
most cases, can be safely moved and executed on top of different virtual machines.
In the case of programming-level virtualization, as implemented by the JVM or the .NET runtime, the
binary code representing application components (jars or assemblies) can run without any
recompilation on any implementation of the corresponding virtual machine.
• Resource sharing: Virtualization allows multiple virtual machines to share the resources of a single
physical machine, such as CPU, memory, storage, and network bandwidth. This improves hardware
utilization and reduces the need for additional physical servers.
• Flexibility: Virtualization allows IT administrators to quickly and easily create, modify, or delete
virtual machines as needed, without the need to purchase and configure additional physical
hardware.
• Hardware independence: Virtual machines are hardware-independent, which means they can run on different
types of physical hardware and can be easily moved between physical servers without needing to reconfigure
the virtual machine.
• Scalability: Virtualization allows organizations to scale their computing resources up or down as needed,
depending on changing business requirements.
• Management: Virtualization provides centralized management tools that allow IT administrators to monitor and
manage multiple virtual machines from a single console, making it easier to troubleshoot and maintain the
virtualized environment.
• Energy Efficiency:
• Virtualization can help organizations reduce their energy consumption by consolidating multiple physical servers
onto a single machine. This can result in lower electricity bills and a reduced carbon footprint.
• Cost Savings:Virtualization can help organizations save money by reducing the need for additional physical
hardware, lowering electricity bills, and streamlining IT operations. This can result in significant cost savings
over time.
Features
• Rapid Deployment
• You can basically deploy virtual resources such as storage, networks, etc very quickly so that it does not take
unrequired time.
• Reducing Hardware Cost
• As more emphasis is placed on using virtual resources, less hardware is used, which lowers the cost
associated with it.
• Resource Allocation
• There are two methods for allocating resources in a virtual environment: dynamic and static.
• Static allocation refers to the virtual environment using a fixed amount of memory that has been assigned to it.
• In dynamic allocation, a virtual environment can expend its memory allocation as and when necessary.
• These three mentioned R’s tell a lot about virtualization. Now let’s start with the architecture of Virtualization.
Benefits of Virtualization
•More flexible and efficient allocation of resources.
•Enhance development productivity.
•It lowers the cost of IT infrastructure.
•Remote access and rapid scalability.
•High availability and disaster recovery.
•Pay per use of the IT infrastructure on demand.
•Enables running multiple operating systems.
Hypervisor
•A hypervisor, is known as a virtual machine monitor or VMM, which is a software that creates and runs
virtual machines (VMs).
•This virtual machine is created and managed by a software or firmware, which is known
as hypervisor(VMM).
•It is a form of virtualization software used in Cloud hosting to divide and allocate the resources on various
pieces of hardware. The program which provides partitioning, isolation, or abstraction is called a
virtualization hypervisor.
•The hypervisor is a hardware virtualization technique that allows multiple guest operating systems (OS)
to run on a single host system at the same time.
•A computer on which a hypervisor runs one or more virtual machines is called a host machine, and each
virtual machine is called a guest machine.
•Multiple instances of a variety of operating systems may share the virtualized hardware resources: for
example, Linux, Windows, and macOS instances can all run on a single physical x86 machine.
Types Of Hypervisors
There are two types of Hypervisor
•Type 1 Hypervisor
•Type 2 Hypervisor
Type 1 Hypervisor
• The hypervisor runs directly on the underlying host system.
• It is also known as a “Native Hypervisor” or “Bare metal hypervisor”. It does not require any base server
operating system.
• The type 1 hypervisor is very much commonly used in the enterprise data center or other server-based
environments.
• These hypervisors run directly on the host's hardware to control the hardware and to manage guest operating
systems.
• It has direct access to hardware resources.
• Examples of Type 1 hypervisors include VMware ESXi, Citrix XenServer, and Microsoft Hyper-V hypervisor.
Pros:
• Such kinds of hypervisors are very efficient because they have
direct access to the physical hardware resources(like Cpu,
Memory, Network, and Physical storage).
• This causes the empowerment of the security because there is
nothing any kind of the third party resource so that attacker
couldn’t compromise with anything.
Cons:
• One problem with Type-1 hypervisors is that they usually need a
dedicated separate machine to perform their operation and to
instruct different VMs and control the host hardware resources.
Type 2 Hypervisors
•It is also known as ‘Hosted Hypervisor”.
•Such kind of hypervisors doesn’t run directly over the underlying hardware rather they run as
an application in a Host system(physical machine). Basically, the software is installed on an
operating system. Hypervisor asks the operating system to make hardware calls.
•An example of a Type 2 hypervisor includes VMware Player or Parallels Desktop.
• Hosted hypervisors are often found on endpoints like PCs. The type-2 hypervisor is very
useful for engineers, and security analysts (for checking malware, or malicious source code
and newly developed applications).
Pros:
• Such kind of hypervisors allows quick and easy access to
a guest Operating System alongside the host machine
running.
• These hypervisors usually come with additional useful
features for guest machines. Such tools enhance the
coordination between the host machine and the guest
machine.
Cons:
• Here there is no direct access to the physical hardware
resources so the efficiency of these hypervisors lags in
performance as compared to the type-1 hypervisors, and
System hardware potential security risks are also there an attacker can
compromise the security weakness if there is access to
the host operating system so he can also access the
guest operating system.