Section 1: KVM Virtualization Basics
Part 1 provides you with an insight into the prevailing technologies in Linux virtualization and its advantages over other virtualization solutions. We will discuss the important data structures and the internal implementation of libvirt, QEMU, and KVM.
This part of the book comprises the following chapters:
- Chapter 1, Understanding Linux Virtualization
- Chapter 2, KVM as a Virtualization Solution
Chapter 1: Understanding Linux Virtualization
Virtualization is the technology that started a big technology shift toward IT consolidation, which provides more efficient use of resources and the cloud as a more integrated, automated, and orchestrated version of virtualization with a focus on not only virtual machines but also additional services. There are a total of 16 chapters in this book, all of which have been lined up to cover all the important aspects of Kernel-based Virtual Machine (KVM) virtualization. We will start with basic KVM topics such as the history of virtualization concepts and Linux virtualization and then move on and look at advanced topics in KVM such as automation, orchestration, virtual networking, storage, and troubleshooting. This chapter will provide you with an insight into the prevailing technologies in Linux virtualization and their advantages over others.
In this chapter, we will cover the following topics:
- Linux virtualization and its basic concepts
- Types of virtualization
- Hypervisor/VMM
- Open source virtualization projects
- What Linux virtualization offers you in the cloud
Linux virtualization and how it all started
Virtualization is a concept that creates virtualized resources and maps them to physical resources. This process can be done using specific hardware functionality (partitioning, via some kind of partition controller) or software functionality (hypervisor). So, as an example, if you have a physical PC-based server with 16 cores running a hypervisor, you can easily create one or more virtual machines with two cores each and start them up. Limits regarding how many virtual machines you can start is something that’s vendor-based. For example, if you’re running Red Hat Enterprise Virtualization v4.x (a KVM-based bare-metal hypervisor), you can use up to 768 logical CPU cores or threads (you can read more information about this at https://access.redhat.com/articles/906543). In any case, hypervisor is going to be the go-to guy that’s going to try to manage that as efficiently as possible so that all of the virtual machine workloads get as much time on the CPU as possible.
I vividly remember writing my first article about virtualization in 2004. AMD just came out with its first consumer 64-bit CPUs in 2003 (Athlon 64, Opteron) and it just threw me for a loop a bit. Intel was still a bit hesitant to introduce a 64-bit CPU – a lack of a 64-bit Microsoft Windows OS might have had something to do with that as well. Linux was already out with 64-bit support, but it was a dawn of many new things to come to the PC-based market. Virtualization as such wasn’t something revolutionary as an idea since other companies already had non-x86 products that could do virtualization for decades (for example, IBM CP-40 and its S/360-40, from 1967). But it sure was a new idea for a PC market, which was in a weird phase with many things happening at the same time. Switching to 64-bit CPUs with multi-core CPUs appearing on the market, then switching from DDR1 to DDR2, and then from PCI/ISA/AGP to PCI Express, as you might imagine, was a challenging time.
Specifically, I remember thinking about the possibilities – how cool it would be to run an OS, and then another couple of OSes on top of that. Working in the publishing industry, you might imagine how many advantages that would offer to anyone’s workflow, and I remember really getting excited about it.
15 or so years of development later, we now have a competitive market in terms of virtualization solutions – Red Hat with KVM, Microsoft with Hyper-V, VMware with ESXi, Oracle with Oracle VM, and Google and other key players duking it out for users and market dominance. This led to the development of various cloud solutions such as EC2, AWS, Office 365, Azure, vCloud Director, and vRealize Automation for various types of cloud services. All in all, it was a very productive 15 years for IT, wouldn’t you say?
But, going back to October 2003, with all of the changes that were happening in the IT industry, there was one that was really important for this book and virtualization for Linux in general: the introduction of the first open source Hypervisor for x86 architecture, called Xen. It supports various CPU architectures (Itanium, x86, x86_64, and ARM), and it can run various OSes – Windows, Linux, Solaris, and some flavors of BSD – and it’s still alive and kicking as a virtualization solution of choice for some vendors, such as Citrix (XenServer) and Oracle (Oracle VM). We’ll get into more technical details about Xen a little bit later in this chapter.
The biggest corporate player in the open source market, Red Hat, included Xen virtualization in initial releases of its Red Hat Enterprise Linux 5, which was released in 2007. But Xen and Red Hat weren’t exactly a match made in heaven and although Red Hat shipped Xen with its Red Hat Enterprise Linux 5 distribution, Red Hat switched to KVM in Red Hat Enterprise Linux 6 in 2010, which was – at the time – a very risky move. Actually, the whole process of migrating from Xen to KVM began in the previous version, with 5.3/5.4 releases, both of which came out in 2009. To put things into context, KVM was a pretty young project back then, just a couple of years old. But there were more than a few valid reasons why that happened, varying from Xen is not in the mainline kernel, KVM is, to political reasons (Red Hat wanted more influence over Xen development, and that influence was fading with time).
Technically speaking, KVM uses a different, modular approach that transforms Linux kernels into fully functional hypervisors for supported CPU architectures. When we say supported CPU architectures, we’re talking about the basic requirement for KVM virtualization – CPUs need to support hardware virtualization extensions, known as AMD-V or Intel VT. To make things a bit easier, let’s just say that you’re really going to have to try very hard to find a modern CPU that doesn’t support these extensions. For example, if you’re using an Intel CPU on your server or desktop PC, the first CPUs that supported hardware virtualization extensions date all the way back to 2006 (Xeon LV) and 2008 (Core i7 920). Again, we’ll get into more technical details about KVM and provide a comparison between KVM and Xen a little bit later in this chapter and in the next.
Types of virtualization
There are various types of virtualization solutions, all of which are aimed at different use cases and are dependent on the fact that we’re virtualizing a different piece of the hardware or software stack, that is, what you’re virtualizing. It’s also worth noting that there are different types of virtualization in terms of how you’re virtualizing – by partitioning, full virtualization, paravirtualization, hybrid virtualization, or container-based virtualization.
So, let’s first cover the five different types of virtualization in today’s IT based on what you’re virtualizing:
- Desktop virtualization (Virtual Desktop Infrastructuree (VDI)): This is used by a lot of enterprise companies and offers huge advantages for a lot of scenarios because of the fact that users aren’t dependent on a specific device that they’re using to access their desktop system. They can connect from a mobile phone, tablet, or a computer, and they can usually connect to their virtualized desktop from anywhere as if they’re sitting at their workplace and using a hardware computer. Benefits include easier, centralized management and monitoring, much more simplified update workflows (you can update the base image for hundreds of virtual machines in a VDI solution and re-link that to hundreds of virtual machines during maintenance hours), simplified deployment processes (no more physical installations on desktops, workstations, or laptops, as well as the possibility of centralized application management), and easier management of compliance and security-related options.
- Server virtualization: This is used by a vast majority of IT companies today. It offers good consolidation of server virtual machines versus physical servers, while offering many other operational advantages over regular, physical …
Год: 2016
Добавил: Admin 16 Авг 21
Проверил: Admin 16 Авг 21
Формат:
PDF (6976 Kb)
- Currently 0/5
Рейтинг: 0/5 (Всего голосов: 0)
Аннотация
Mastering KVM Virtualization
Похожие книги
Комментарии к книге «Mastering KVM Virtualization»
Комментарий не найдено. Будьте первыми!
Чтобы оставить комментарий или поставить оценку книге Вам нужно зайти на сайт или зарегистрироваться
$5 Tech Unlocked 2021!
Buy and download this Book for only $5 on PacktPub.com
If you have read this book, please leave a review on Amazon.com. Potential readers can then use your unbiased opinion to help them make purchase decisions. Thank you. The $5 campaign runs from December 15th 2020 to January 13th 2021.
KVM Virtualization Cookbook
This is the code repository for KVM Virtualization Cookbook, published by Packt. It contains all the supporting project files necessary to work through the book from start to finish.
About the Book
Virtualization technologies such as KVM allow for better control over the available server resources, by deploying multiple virtual instances on the same physical host, or clusters of compute resources. With KVM it is possible to run various workloads in isolation with the hypervisor layer providing better tenant isolation and higher degree of security.
This book will provide a deep dive into deploying KVM virtual machines using qemu and libvirt and will demonstrate practical examples on how to run, scale, monitor, migrate and backup such instances. You will also discover real production ready recipes on deploying KVM instances with OpenStack and how to programatically manage the life cycle of KVM virtual machines using Python. You will learn numerous tips and techniques which will help you deploy & plan the KVM infrastructure. Next, you will be introduced to the working of libvirt libraries and the iPython development environment.
Finally, you will be able to tune your Linux kernel for high throughput and better performance. By the end of this book, you will gain all the knowledge needed to be an expert in working with the KVM virtualization infrastructure.
Instructions and Navigations
All of the code is organized into folders. Each folder starts with a number followed by the application name. For example, Chapter05.
The code will look like the following:
conn = libvirt.open('qemu:///system')
if conn == None:
print 'Failed to connecto to the hypervizor'
exit(1)
Software requirements:
- Ubuntu 14.04.5 LTS Architeture
Hardware requirements:
- Machine at least 8GB RAM, processors with virtualization extensions and at least one network adapter
Related Products:
-
Mastering KVM Virtualization
-
Getting Started with Oracle VM VirtualBox
-
Mastering KVM Virtualization
Download a free PDF
If you have already purchased a print or Kindle version of this book, you can get a DRM-free PDF version at no cost.
Simply click on the link to claim your free PDF.
https://packt.link/free-ebook/9781788294676
Virtualization empowers us to reinforce IT assets into single unit with the goal that they can be shared over a system and satisfy the contracting assets and developing business needs. It includes and subtracts distinctive registering assets to present or past working situations with various kinds of techniques like equipment and programming accumulation, machine recreation, copying and numerous others. Virtualization is basic piece of distributed computing as it backings various Virtual Machines with various facilitating situations. Cloud stage not just deals with the assets of the cloud foundation additionally benefits client on request necessities and assignment planning on virtual machines. In this paper authors have chosen the bare metal hypervisor KVM/QEMU, libvirt and Ubuntu operating system for the deployment of virtualization. The aspiration of the paper is to provide the qualitative implementation and application of the bare metal hypervisor for the virtualization learning aspirants in the fewer infrastructures. The complete deployment with scripts and screen of the implementation steps has been shown.