45
1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization Slides based on Text by Silberschatz, Galvin, Gagne Various sources

CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

  • Upload
    lynga

  • View
    219

  • Download
    0

Embed Size (px)

Citation preview

Page 1: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

1 1

Colorado State UniversityYashwant K Malaiya

Spring 2018 Lecture 26

CS370 Operating Systems

Virtualization

Slides based on • Text by Silberschatz, Galvin, Gagne • Various sources

Page 2: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

2

Virtualization

• Why we need virtualization?

• The concepts and terms

• Brief history of virtualization

• Types of virtualization

• Implementation Issues

Page 3: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

3

Project Notes

• 5/1: Tu Project final report

• 5/1: Research Poster session 9:15 to 11:15 AM (electronic copy due 5 PM.)

– Presenters: all others: A-L: 9:30-10:05 M-Z: 10:10-10:45

• 5/2 Project Slides for both options (3-4): Piazza

• 5/1-5/3: Planned Development demos

• 5/7 Project reviews using form provided

– 1 Dev, 1 Res, also peer (using form)

• 5/10 Thurs Final

Page 4: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

4

Virtualization

• Processors have gradually become very powerful

• Dedicated servers can be very underutilized (5-15%)

• Virtualization allow a single server to support several virtualized servers: typical consolidation ratio 6:1

• Power cost a major expense for data centers– Companies frequently locate their data centers in the middle of

nowhere where power cost is low

• If a hardware server crashes, would be nice to migrate the load to another one.

• A key component of cloud computing

Page 5: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

5

Virtual Machines (VM)

• Virtualization technology enables a single PC/server to simultaneously run multiple operating systems or multiple sessions of a single OS.

• A machine with virtualization can host many applications, including those that run on different operating systems, on a single platform.

• The host operating system can support a number of virtual machines, each of which has the characteristics of a particular OS.

• The software that enables virtualization is a virtual machine monitor (VMM), or hypervisor.

Page 6: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

6

Virtual Machines (VM)

Traditional physical machine

Hypervisor with virtual machines

Page 7: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

7

Terminology

Virtualization

• Hypervisor based– Full virtualization

– Para virtualization

– Host OS virtualization

• Container system

• Environment virtualization– Java virtual machine, Dalvic virtual machine

• Software simulation of hardware/ISA– Android JDK

– SoftPC etc.

• Emulation using microcode

Page 8: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

8

Brief history

• Early 1960s IBM experimented with two independently developed hypervisors - SIMMON and CP-40

• In 1974, Gerald Popek and Robert Goldberg published a paper which listed what conditions a computer architecture should satisfy to support virtualization efficiently – Privileged instructions: Those that trap if the processor is in user mode

and do not trap if it is in system mode (supervisor mode).

– Sensitive instructions: that attempt to change the configuration of resources in the system or whose behavior or result depends on the configuration of resources

– Theorem 1. For any conventional third-generation computer, an effective VMM may be constructed if the set of sensitive instructions for that computer is a subset of the set of privileged instructions.

– The x86 architecture that originated in the 1970s did not meet these for requirements for decades.

Page 9: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

9

Brief history

• Stanford researchers developed a new hypervisor and then founded VMware

– first virtualization solution for x86 in 1999

– Linux, windows

• Others followed

– Xen, 2003 University of Cambridge, Xen Project community

– KVM, 2012

– VirtualBox (Innotek GmbH/Sun/Oracle) , 2007

– Hyper-V (Microsoft), 2008

Page 10: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

10

Implementation of VMMs

– Type 1 hypervisors - Operating-system-like software built to provide virtualization. Runs on ‘bare metal”.

• Including VMware ESX, Joyent SmartOS, and Citrix XenServer

– Also includes general-purpose operating systems that provide standard functions as well as VMM functions

• Including Microsoft Windows Server with HyperV and RedHat Linux with KVM

– Type 2 hypervisors - Applications that run on standard operating systems but provide VMM features to guest operating systems

• Includiing VMware Workstation and Fusion, Parallels Desktop, and Oracle VirtualBox

Page 11: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

11

Implementation of VMMs

https://microkerneldude.files.wordpress.com/2012/01/type1-vs-2.png

Page 12: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

12

Market share

All 3 are Type 1 http://www.virtualizationsoftware.com/top-5-enterprise-type-1-hypervisors/

Page 13: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

13

User mode and Kernel (supervisor) mode

• Special instructions:

• Depending on whether it is executed in kernel/user mode – “Sensitive instructions”

• Some instructions cause a trap when executed in user-mode – “Privileged instructions”

• A machine is virtualizable only if sensitive instructions are a subset of privileged instructions– Intel’s 386 did not always do that. Several sensitive 386 instructions

were ignored if executed in user mode.

• Fixed in 2005

– Intel CPUs: VT (Virtualization Technology)

– AMD CPUs: SVM (Secure Virtual Machine)

Page 14: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

14

Virtualization support

• Create containers in which VMs can be run

• When a guest OS is started in a container, continues to run until it causes an exception and traps to the hypervisor – For e.g. by executing an I/O instruction

• Set of operations that trap is controlled by a hardware bit map set by hypervisor – trap-and-emulate approach becomes possible

Page 15: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

15

Implementation of VMMs

What problems do you see?

• What mode does hypervisor run in? Guest OSs?

• Are Guest OSs aware of hypervisor?

• How is memory managed?

• How do we know what is the best choice?

Page 16: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

16

Terms

• Guest Operating System – The OS running on top of the hypervisor

• Host Operating System – For a type 2 hypervisor: the OS that runs on the hardware

¨executions

Page 17: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

17

Virtual Machine (VM) as a software construct

• Each VM is configured with some number of processors, some amount of RAM, storage resources, and connectivity through the network ports

• Once the VM is created it can be activated on like a physical server, loaded with an operating system and software solutions, and used just like a physical server

• But unlike a physical server, VM only sees the resources it has been configured with, not all of the resources of the physical host itself

• The hypervisor facilitates the translation and I/O between the virtual machine and the physical server.

Page 18: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

18

Virtual Machine (VM) as a set of files

• Configuration file describes the attributes of the virtual machine containing– server definition,

– how many virtual processors (vCPUs)

– how much RAM is allocated,

– which I/O devices the VM has access to,

– how many network interface cards (NICs) are in the virtual server

– the storage that the VM can access

• When a virtual machine is instantiated, additional files are created for logging, for memory paging etc.

• Copying a VM produces not only a backup of the data but also a copy of the entire server, including the operating system, applications, and the hardware configuration itself

Page 19: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

19

Virtualization benefits

• Run multiple, OSes on a single machine– Consolidation, app dev, …

• Security: Host system protected from VMs, VMs protected from each other– Sharing though shared file system volume, network communication

• Freeze, suspend, running VM– Then can move or copy somewhere else and resume

• Live migration

– Snapshot of a given state, able to restore back to that state

– Clone by creating copy and running both original and copy

• Hence – cloud computing

Page 20: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

20

Building Block – Trap and Emulate

• VM needs two modes: both in real user mode– virtual user mode and virtual kernel mode

• When Guest OS attempts to execute a privileged instruction, what happens?– Causes a trap

– VMM gains control, analyzes error, executes operation as attempted by guest

– Returns control to guest in user mode

– Known as trap-and-emulate

• This was the technique used for implementing floating point instructions in CPUs without floating point coprocessor

Page 21: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

21

Sensitive instructions

• Some CPUs didn’t have clean separation between privileged and non-privileged instructions– Sensitive instructions

• Consider Intel x86 popf instruction

• If CPU in privileged mode -> all flags replaced

• If CPU in user mode -> on some flags replaced

– No trap is generated

• Binary translation (complex) solves the problem1. If guest VCPU is in user mode, guest can run instructions natively

2. If guest VCPU in kernel mode (guest believes it is in kernel mode)1. VMM examines every instruction guest is about to execute by reading a

few instructions ahead of program counter

2. Special instructions translated into new set of instructions that perform equivalent task (for example changing the flags in the VCPU)

3. Cached translations can reduce overhead

Page 22: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

22

Type 1 Hypervisors

• Guest OSs believe they are running on bare metal, are unaware of hypervisor

– are not modified

– Better performance

• Choice for data centers

• Consolidation of multiple OSes and apps onto less HW

• Move guests between systems to balance performance

• Snapshots and cloning

• Create run and manage guest OSes

– Run in kernel mode

– Implement device drivers

– Also provide other traditional OS services like CPU and memory management

• Examples: VMWare esx (dedicated) , Windows with Hyper-V (includes OS)

Page 23: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

23

Type 2 Hypervisors

• Run on top of host OS

• VMM is simply a process, managed by host OS

– host doesn’t know they are a VMM running guests

• poorer overall performance because can’t take advantage of some HW features

• Host OS is just a regular one

– Individuals could have Type 2 hypervisor on native host (perhaps windows), run one or more guests (perhaps Linux, MacOS)

Page 24: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

24

Full vs Para-virtualization

• Full virtualization: Guest OS is unaware of the hypervisor. It thinks it is running on bare metal.

• Para-virtualization: Guest OS is modified and optimized. It sees underlying hypervisor.

– Introduced and developed by Xen• Modifications needed: Linux 1.36%, XP: 0.04% of code base

– Does not need as much hardware support

– allowed virtualization of older x86 CPUs without binary translation

– Not used by Xen on newer processors

Page 25: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

25

CPU Scheduling

• One or more virtual CPUs (vCPUs) per guest

– Can be adjusted throughout life of VM

• When enough CPUs for all guests

– VMM can allocate dedicated CPUs, each guest much like native operating system managing its CPUs

• Usually not enough CPUs (CPU overcommitment)

– VMM can use scheduling algorithms to allocate vCPUs

– Some add fairness aspect

Page 26: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

26

CPU Scheduling (cont)

• Oversubscription of CPUs means guests may get CPU cycles they expect

– Time-of-day clocks may be incorrect

– Some VMMs provide application to run in each guest to fix time-of-day

Page 27: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

27

Evaluation form

Page 28: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

28

Memory Management

Memory mapping:

• On a bare metal machine: Each process has its own virtual address space. OS uses page table/TLB to map Virtual page number (VPN) to Physical page number (PPN) (physical memory is shared). Each process has its own page table/TLB.

VPN -> PPN

Page 29: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

29

Memory Management

Memory mapping:

• On a bare metal machine:

– VPN -> PPN

• VMM: Real physical memory (machine memory) is shared by the OSs. Need to map PPN of each VM to MPN (Shadow page table)

PPN ->MPN

• Where is this done?– In Full virtualization?

– In Para virtualization?

Page 30: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

30

Memory Management

• VMM: Real physical memory (machine memory) is shared by the OSs. Need to map PPN of each VM to MPN (Shadow page table)

PPN ->MPN

• Where is this done?– In Full virtualization? Has to be done by hypervisor.

Guest OS knows nothing about MPN.

– In Para virtualization? May be done by guest OS. It knows about hardware. Commands to VMM are “hypercalls”

• Full virtualization: PT/TLB updates are trapped to VMM. It needs

to do VPN->PPN ->MPN. It can do VPN->MPN directly (VMware ESX)

Page 31: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

31

Handling memory oversubscription

Oversubscription solutions:

– Deduplication by VMM determining if same page loaded more than once, memory mapping the same page into multiple guests

– Double-paging, the guest page table indicates a page is in a physical frame but the VMM moves some of those to disk.

– Install a pseudo-device driver in each guest (it looks like a device

driver to the guest kernel but really just adds kernel-mode code to the guest) • Balloon memory manager communicates with VMM and is told

to allocate or deallocate memory to decrease or increase physical memory use of guest, causing guest OS to free or have more memory available.

Page 32: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

32

Live Migration

Running guest can be moved between systems, without interrupting user access to the guest or its apps

– for resource management,

– maintenance downtime windows, etc

• Migration from source VMM to target VMM

– Needs to migrate all pages gradually, without interrupting execution (details in next slide)

– Eventually source VMM freezes guest, sends vCPU’s final state, sends other state details, and tells target to start running the guest

– Once target acknowledges that guest running, source terminates guest

Page 33: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

33

Live Migration

• Migration from source VMM to target VMM

– Source VMM establishes a connection with the target VMM

– Target creates a new guest by creating a new VCPU, etc

– Source sends all read-only memory pages to target

– Source starts sending all read-write pages to the target, marking them as clean

• repeats, as during that step some pages were modified by the guest and are now dirty.

– Source VMM freezes guest, sends VCPU’s final state, other state details, final dirty pages, and tells target to start running the guest

• Once target acknowledges that guest running, source terminates guest

Page 34: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

34

VIRTUAL APPLIANCES: “shrink-wrapped” virtual machines

• Developer can construct a virtual machine with– required OS, compiler, libraries, and application code

– Freeze them as a unit … ready to run

• Customers get a complete working package

• Virtual appliances: “shrink-wrapped” virtual machines

• Amazon’s EC2 cloud offers many pre-packaged virtual appliances examples of Software as a service

Page 35: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

35 35

Colorado State UniversityYashwant K Malaiya

Spring 2018 Lecture 27

CS370 Operating Systems

Data Centers &Cloud Computing

Slides based on • Text by Silberschatz, Galvin, Gagne • Various sources

Page 36: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

36

Data Centers

• Large server and storage farms– 1000s-100,000 of servers

– Many PBs of data

• Used by– Enterprises for server applications

– Internet companies

– Some of the biggest DCs are owned by Google, Facebook, etc

• Used for– Data processing

– Web sites

– Business apps

Page 37: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

37

Data Center architecture

Traditional - static– Applications run on physical servers

– System administrators monitor and manually

manage servers

– Storage Array Networks (SAN) or Network Attached

Storage (NAS) to hold data

Modern – dynamic with larger scale– Run applications inside virtual machines

– Flexible mapping from virtual to physical resources

– Increased automation, larger scale

Page 38: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

38

Data Center architecture

Giant warehouses with:– Racks of servers

– Storage arrays

– Cooling infrastructure

– Power converters

– Backup generators

Or with containers– Each container filled with thousands of servers

– Can easily add new containers

– “Plug and play”

– Pre-assembled, cheaper, easily expanded

Page 39: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

39

Server Virtualization

Allows a server to be “sliced” into Virtual Machines

– VM has own OS/applications

– Rapidly adjust resource allocations

– VM migration within a LAN

• Virtual Servers– Consolidate servers

– Faster deployment

– Easier maintenance

• Virtual Desktops– Host employee desktops in VMs

– Remote access with thin clients

– Desktop is available anywhere

– • Easier to manage and maintain

Page 40: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

40

Data Center Challenges

Resource management– How to efficiently use server and storage

resources?

– Many apps have variable, unpredictable workloads

– Want high performance and low cost

– Automated resource management

– Performance profiling and prediction

Energy Efficiency– Servers consume huge amounts of energy

– Want to be “green”

– Want to save money

Page 41: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

41

Data Center Challenges

Efficiency captured as Power Usage Effectiveness

• Ratio of IT Power / Total Power

• typical: 1.7, Google PUE ~ 1.1)

http://perspectives.mvdirona.com/2008/11/28/CostOfPowerInLargeScaleDataCenters.aspx

Page 42: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

42

Economy of Scale

Larger data centers can be cheaper to buy

and run than smaller ones– Lower prices for buying equipment in bulk

– Cheaper energy rates

– Automation allows small number of sys admins to

– manage thousands of servers

– General trend is towards larger mega data centers

– 100,000s of servers

– Has helped grow the popularity of cloud computing

Page 43: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

43

Economy of Scale

ResourceCost in

Medium DCCost in

Very Large DC Ratio

CPU cycle cost 2 picocents < 0.5 picocents

Network $95 / Mbps / month $13 / Mbps / month 7.1x

Storage $2.20 / GB / month $0.40 / GB / month 5.7x

Administration ≈140 servers/admin >1000 servers/admin 7.1x

Page 44: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

44

Data Center Challenges

Reliability Challenges

Typical failures in a year of a Google data center:

• 20 rack failures (40-80 machines instantly

disappear, 1-6 hours to get back)

• 3 router failures (have to immediately pull traffic

for an hour)

• 1000 individual machine failures

• thousands of hard drive failures

http://static.googleusercontent.com/external_content/untrusted_dlcp/research.google.com/en/us/people/jeff/stanfor

d-295-talk.pdf

Page 45: CS370 Operating Systemscs370/Spring18/lectures/16virtualizationL26.pdf · 1 1 Colorado State University Yashwant K Malaiya Spring 2018 Lecture 26 CS370 Operating Systems Virtualization

45

Virtualization

• Processors have gradually become very powerful

• Dedicated servers can be very underutilized (5-15%)

• Virtualization allow a single server to support several virtualized servers: typical consolidation ratio 6:1

• Power cost a major expense for data centers– Companies frequently locate their data centers in the middle of

nowhere where power cost is low

• If a hardware server crashes, would be nice to migrate the load to another one.

• A key component of cloud computing