Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
vSphere Virtual Machine Management
vSphere Virtual Machine Management

vSphere Virtual Machine Management: This tutorial will help VMware administrators fine-tune and expand their expertise with vSphere. From creating and configuring virtual machines to optimizing performance, it's all here in a crystal clear series of chapters.

eBook
€8.99 €39.99
Paperback
€48.99
Subscription
Free Trial
Renews at €18.99p/m

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing
Table of content icon View table of contents Preview book icon Preview Book

vSphere Virtual Machine Management

Chapter 1. Virtual Machine Concepts

Ever since VMware was founded in 1998, it has been creating stable x86 virtualization platforms that allow multiple guest operating systems and applications to run on a single physical server. Before an administrator can begin creating and configuring vSphere virtual machines, it is important to understand what a virtual machine is and the concepts behind virtualizing hardware.

In this chapter, you will learn:

  • What a virtual machine is

  • Components of a virtual machine

  • Why to use virtual machines

  • Files that make up a virtual machine

  • The four primary resources

  • VMware Tools

The multiple instances of Windows or Linux systems that are running on an ESXi host are commonly referred to as a virtual machine (VM). Any reference to a guest operating system (OS) is an instance of Linux, Windows, or any other supported operating system that is installed on the VM.

vSphere virtual machines


At the heart of virtualization lies the virtual machine. A virtual machine is a set of virtual hardware whose characteristics are determined by a set of files; it is this virtual hardware that a guest operating system is installed on. A virtual machine runs an operating system and a set of applications just like a physical server. A virtual machine comprises a set of configuration files and is backed by the physical resources of an ESXi host. An ESXi host is the physical server that has the VMware hypervisor, known as ESXi, installed. Each virtual machine is equipped with virtual hardware and devices that provide the same functionality as having physical hardware.

Virtual machines are created within a virtualization layer, such as ESXi running on a physical server. This virtualization layer manages requests from the virtual machine for resources such as CPU or memory. It is the virtualization layer that is responsible for translating these requests to the underlying physical hardware.

Each virtual machine is granted a portion of the physical hardware. All VMs have their own virtual hardware (there are important ones to note, called the primary 4: CPU, memory, disk, and network). Each of these VMs is isolated from the other and each interacts with the underlying hardware through a thin software layer known as the hypervisor. This is different from a physical architecture in which the installed operating system interacts with installed hardware directly.

With virtualization, there are many benefits, in relation to portability, security, and manageability that aren't available in an environment that uses a traditional physical infrastructure. However, once provisioned, virtual machines use many of the same principles that are applied to physical servers.

The preceding diagram demonstrates the differences between the traditional physical architecture (left) and a virtual architecture (right). Notice that the physical architecture typically has a single application and a single operating system using the physical resources. The virtual architecture has multiple virtual machines running on a single physical server, accessing the hardware through the thin hypervisor layer.

Virtual machine components


When a virtual machine is created, a default set of virtual hardware is assigned to it. VMware provides devices and resources that can be added and configured to the virtual machine. Not all virtual hardware devices will be available to every single virtual machine; both the physical hardware of the ESXi host and the VM's guest OS must support these configurations. For example, a virtual machine will not be capable of being configured with more vCPUs than the ESXi host has logical CPU cores.

The options and configurations for these devices will be explained further in Chapter 2, Creating a Virtual Machine Using the Wizard. For example, we'll explore the effects of assigning virtual sockets versus that of assigning virtual cores on the virtual machine's vCPU.

The virtual hardware available includes:

  • BIOS: Phoenix Technologies 6.00 that functions like a physical server BIOS. Virtual machine administrators are able to enable/disable I/O devices, configure boot order, and so on.

  • DVD/CD-ROM: NEC VMware IDE CDR10 that is installed by default in new virtual machines created in vSphere. The DVD/CD-ROM can be configured to connect to the client workstation DVD/CD-ROM, an ESXi host DVD/CD-ROM, or even an .iso file located on a datastore. DVD/CD-ROM devices can be added to or removed from a virtual machine.

  • Floppy drive: This is installed by default with new virtual machines created in vSphere. The floppy drive can be configured to connect to the client device's floppy drive, a floppy device located on the ESXi host, or even a floppy image (.flp) located on a datastore. Floppy devices can be added to or removed from a virtual machine.

  • Hard disk: This stores the guest operating system, program files, and any other data associated with a virtual machine. The virtual disk is a large file, or potentially a set of files, that can be easily copied, moved, and backed up.

  • IDE controller: Intel 82371 AB/EB PCI Bus Master IDE Controller that presents two Integrated Drive Electronics (IDE) interfaces to the virtual machine by default. This IDE controller is a standard way for storage devices, such as floppy drives and CD-ROM drives, to connect to the virtual machine.

  • Keyboard: This mirrors the keyboard that is first connected to the virtual machine console upon initial console connection.

  • Memory: This is the virtual memory size configured for the virtual machine that determines the guest operating system's memory size.

  • Motherboard/Chipset: The motherboard uses VMware proprietary devices that are based on the following chips:

    • Intel 440BX AGPset 82443BX Host Bridge/Controller

    • Intel 82093 AA I/O Advanced Programmable Interrupt Controller

    • Intel 82371 AB (PIIX4) PCI ISA IDE Xcelerator

    • National Semiconductor PC87338 ACPI 1.0 and PC98/99 Compliant Super I/O

  • Network adapter: ESXi networking features provide communication between virtual machines residing on the same ESXi host, between VMs residing on different ESXi hosts, and between VMs and physical machines. When configuring a VM, network adapters (NICs) can be added and the adapter type can be specified.

  • Parallel port: This is an interface for connecting peripherals to the virtual machine. Virtual parallel ports can be added to or removed from the virtual machine.

  • PCI controller: This is a bus located on the virtual machine motherboard, communicating with components such as a hard disk. A single PCI controller is presented to the virtual machine. This cannot be configured or removed.

  • PCI device: DirectPath devices can be added to a virtual machine. The devices must be reserved for PCI pass-through on the ESXi host that the virtual machine runs on. Keep in mind that snapshots are not supported with DirectPath I/O pass-through device configuration. For more information on virtual machine snapshots, see http://vmware.com/kb/1015180.

  • Pointing device: This mirrors the pointing device that is first connected to the virtual machine console upon initial console connection.

  • Processor: This specifies the number of sockets and core for the virtual processor. This will appear as AMD or Intel to the virtual machine guest operating system depending upon the physical hardware.

  • Serial port: This is an interface for connecting peripherals to the virtual machine. The virtual machine can be configured to connect to a physical serial port, a file on the host, or over the network. The serial port can also be used to establish a direct connection between two VMs. Virtual serial ports can be added to or removed from the virtual machine.

  • SCSI controller: This provides access to virtual disks. The virtual SCSI controller may appear as one of several different types of controllers to a virtual machine, depending on the guest operating system of the VM. Editing the VM configuration can modify the SCSI controller type, a SCSI controller can be added, and a virtual controller can be configured to allocate bus sharing.

  • SCSI device: A SCSI device interface is available to the virtual machine by default. This interface is a typical way to connect storage devices (hard drives, floppy drives, CD-ROMs, and so on) to a VM. SCSI device that can be added to or removed from a virtual machine.

  • SIO controller: The Super I/O controller provides serial and parallel ports, and floppy devices, and performs system management activities. A single SIO controller is presented to the virtual machine. This cannot be configured or removed.

  • USB controller: This provides USB functionality to the USB ports managed. The virtual USB controller is a software virtualization of the USB host controller function in a VM.

  • USB device: Multiple USB devices may be added to a virtual machine. These can be mass storage devices or security dongles. The USB devices can be connected to a client workstation or to an ESXi host.

  • Video controller: This is a VMware Standard VGA II Graphics Adapter with 128 MB video memory.

  • VMCI: The Virtual Machine Communication Interface provides high-speed communication between the hypervisor and a virtual machine. VMCI can also be enabled for communication between VMs. VMCI devices cannot be added or removed.

Uses of virtual machines


In any infrastructure, there are many business processes that have applications supporting them. These applications typically have certain requirements, such as security or performance requirements, which may limit the application to being the only thing installed on a given machine. Without virtualization, there is typically a 1:1:1 ratio for server hardware to an operating system to a single application. This type of architecture is not flexible and is inefficient due to many applications using only a small percentage of the physical resources dedicated to it, effectively leaving the physical servers vastly underutilized. As hardware continues to get better and better, the gap between the abundant resources and the often small application requirements widens. Also, consider the overhead needed to support the entire infrastructure, such as power, cooling, cabling, manpower, and provisioning time. A large server sprawl will cost more money for space and power to keep these systems housed and cooled.

Virtual infrastructures are able to do more with less—fewer physical servers are needed due to higher consolidation ratios. Virtualization provides a safe way of putting more than one operating system (or virtual machine) on a single piece of server hardware by isolating each VM running on the ESXi host from any other. Migrating physical servers to virtual machines and consolidating onto far fewer physical servers means lowering monthly power and cooling costs in the datacenter. Fewer physical servers can help reduce the datacenter footprint; fewer servers means less networking equipment, fewer server racks, and eventually less datacenter floor space required. Virtualization changes the way a server is provisioned. Initially it took hours to build a cable and install the OS; now it takes only seconds to deploy a new virtual machine using templates and cloning.

VMware offers a number of advanced features that aren't found in a strictly physical infrastructure. These features, such as High Availability, Fault Tolerance, and Distributed Resource Scheduler, help with increased uptime and overall availability. These technologies keep the VMs running or give the ability to quickly recover from unplanned outages. The ability to quickly and easily relocate a VM from one ESXi host to another is one of the greatest benefits of using vSphere virtual machines.

In the end, virtualizing the infrastructure and using virtual machines will help save time, space, and money. However, keep in mind that there are some upfront costs to be aware of. Server hardware may need to be upgraded or new hardware purchased to ensure compliance with the VMware Hardware Compatibility List (HCL). Another cost that should be taken into account is the licensing costs for VMware and the guest operating system; each tier of licensing allows for more features but drives up the price to license all of the server hardware.

The primary virtual machine resources


Virtualization decouples physical hardware from an operating system. Each virtual machine contains a set of its own virtual hardware and there are four primary resources that a virtual machine needs in order to correctly function. These are CPU, memory, network, and hard disk. These four resources look like physical hardware to the guest operating systems and applications. The virtual machine is granted access to a portion of the resources at creation and can be reconfigured at any time thereafter. If a virtual machine experiences constraint, one of the four primary resources is generally where a bottleneck will occur.

In a traditional architecture, the operating system interacts directly with the server's physical hardware without virtualization. It is the operating system that allocates memory to applications, schedules processes to run, reads from and writes to attached storage, and sends and receives data on the network. This is not the case with a virtualized architecture. The virtual machine guest operating system still does the aforementioned tasks, but also interacts with virtual hardware presented by the hypervisor.

In a virtualized environment, a virtual machine interacts with the physical hardware through a thin layer of software known as the virtualization layer or the hypervisor; in this case the hypervisor is ESXi. This hypervisor allows the VM to function with a degree of independence from underlying physical hardware. This independence is what allows vMotion and Storage vMotion functionality. The following diagram demonstrates a virtual machine and its four primary resources:

This section will provide an overview of each of the "primary four" resources. Configurations for these resources will be discussed in Chapter 2, Creating a Virtual Machine Using the Wizard and Chapter 4, Advanced Virtual Machine Settings.

CPU

The virtualization layer runs CPU instructions to make sure that the virtual machines run as though accessing the physical processor on the ESXi host. Performance is paramount for CPU virtualization, and therefore will use the ESXi host physical resources whenever possible. The following image displays a representation of a virtual machine's CPU:

A virtual machine can be configured with up to 64 virtual CPUs (vCPUs) as of vSphere 5.5. The maximum vCPUs able to be allocated depends on the underlying logical cores that the physical hardware has. Another factor in the maximum vCPUs is the tier of vSphere licensing; only Enterprise Plus licensing allows for 64 vCPUs. The VMkernel includes a CPU scheduler that dynamically schedules vCPUs on the ESXi host's physical processors.

The VMkernel scheduler, when making scheduling decisions, considers socket-core-thread topology. A socket is a single, integrated circuit package that has one or more physical processor cores. Each core has one or more logical processors, also known as threads. If hyperthreading is enabled on the host, then ESXi is capable of executing two threads, or sets of instruction, simultaneously. Effectively, hyperthreading provides more logical CPUs to ESXi on which vCPUs can be scheduled, providing more scheduler throughput. However, keep in mind that hyperthreading does not double the core's power. During times of CPU contention, when VMs are competing for resources, the VMkernel timeslices the physical processor across all virtual machines to ensure that the VMs run as if having a specified number of vCPUs.

VMware vSphere Virtual Symmetric Multiprocessing (SMP) is what allows the virtual machines to be configured with up to 64 virtual CPUs, which allows a larger CPU workload to run on an ESXi host. Though most supported guest operating systems are multiprocessor aware, many guest OSes and applications do not need and are not enhanced by having multiple vCPUs. Check vendor documentation for operating system and application requirements before configuring SMP virtual machines.

Memory

In a physical architecture, an operating system assumes that it owns all physical memory in the server, which is a correct assumption. A guest operating system in a virtual architecture also makes this assumption but it does not, in fact, own all of the physical memory. A guest operating system in a virtual machine uses a contiguous virtual address space that is created by ESXi as its configured memory. The following image displays a representation of a virtual machine's memory:

Virtual memory is a well-known technique that creates this contiguous virtual address space, allowing the hardware and operating system to handle the address translation between the physical and virtual address spaces. Since each virtual machine has its own contiguous virtual address space, this allows ESXi to run more than one virtual machine at the same time. The virtual machine's memory is protected against access from other virtual machines.

This effectively results in three layers of virtual memory in ESXi: physical memory, guest operating system physical memory, and guest operating system virtual memory. The VMkernel presents a portion of physical host memory to the virtual machine as its guest operating system physical memory. The guest operating system presents the virtual memory to the applications.

The virtual machine is configured with a set of memory; this is the sum that the guest OS is told it has available to it. A virtual machine will not necessarily use the entire memory size; it only uses what is needed at the time by the guest OS and applications. However, a VM cannot access more memory than the configured memory size. A default memory size is provided by vSphere when creating the virtual machine. It is important to know the memory needs of the application and guest operating system being virtualized so that the virtual machine's memory can be sized accordingly.

Network

There are two key components with virtual networking: the virtual switch and virtual Ethernet adapters. A virtual machine can be configured with up to ten virtual Ethernet adapters, called vNICs. The following image displays a representation of a virtual machine's vNIC:

Virtual network switching is software interfacing between virtual machines at the vSwitch level until the frames hit an uplink or a physical adapter, exiting the ESXi host and entering the physical network. Virtual networks exist for virtual devices; all communication between the virtual machines and the external world (physical network) goes through vNetwork standard switches or vNetwork distributed switches.

Virtual networks operate on layer 2, data link, of the OSI model. A virtual switch is similar to a physical Ethernet switch in many ways. For example, virtual switches support the standard VLAN (802.1Q) implementation and have a forwarding table, like a physical switch. An ESXi host may contain more than one virtual switch. Each virtual switch is capable of binding multiple vmnics together in a network interface card (NIC) team, which offers greater availability to the virtual machines using the virtual switch.

There are two connection types available on a virtual switch: a port group and a VMkernel port. Virtual machines are connected to port groups on a virtual switch, allowing access to network resources. VMkernel ports provide a network service to the ESXi host to include IP storage, management, vMotion, and so on. Each VMkernel port must be configured with its own IP address and network mask. The port groups and VMkernel ports reside on a virtual switch and connect to the physical network through the physical Ethernet adapters known as vmnics. If uplinks (vmnics) are associated with a virtual switch, then the virtual machines connected to a port group on this virtual switch will be able to access the physical network.

Disk

In a non-virtualized environment, physical servers connect directly to storage, either to an external storage array or to their internal hard disk arrays to the server chassis. The issue with this configuration is that a single server expects total ownership of the physical device, tying an entire disk drive to one server. Sharing storage resources in non-virtualized environments can require complex filesystems and migration to file-based Network Attached Storage (NAS) or Storage Area Networks (SAN). The following image displays a representation of a virtual disk:

Shared storage is a foundational technology that allows many things to happen in a virtual environment (High Availability, Distributed Resource Scheduler, and so on). Virtual machines are encapsulated in a set of discrete files stored on a datastore. This encapsulation makes the VMs portable and easy to be cloned or backed up. For each virtual machine, there is a directory on the datastore that contains all of the VM's files. A datastore is a generic term for a container that holds files as well as .iso images and floppy images. It can be formatted with VMware's Virtual Machine File System (VMFS) or can use NFS. Both datastore types can be accessed across multiple ESXi hosts.

VMFS is a high-performance, clustered filesystem devised for virtual machines that allows a virtualization-based architecture of multiple physical servers to read and write to the same storage simultaneously. VMFS is designed, constructed, and optimized for virtualization. The newest version, VMFS-5, exclusively uses 1 MB block size, which is good for large files, while also having an 8 KB subblock allocation for writing small files such as logs. VMFS-5 can have datastores as large as 64 TB. The ESXi hosts use a locking mechanism to prevent the other ESXi hosts accessing the same storage from writing to the VMs' files. This helps prevent corruption.

Several storage protocols can be used to access and interface with VMFS datastores; these include Fibre Channel, Fibre Channel over Ethernet, iSCSI, and direct attached storage. NFS can also be used to create a datastore. VMFS datastore can be dynamically expanded, allowing the growth of the shared storage pool with no downtime.

vSphere significantly simplifies accessing storage from the guest OS of the VM. The virtual hardware presented to the guest operating system includes a set of familiar SCSI and IDE controllers; this way the guest OS sees a simple physical disk attached via a common controller. Presenting a virtualized storage view to the virtual machine's guest OS has advantages such as expanded support and access, improved efficiency, and easier storage management.

Virtual machine files


vSphere administrators should know the components of virtual machines. There are multiple VMware file types that are associated with and make up a virtual machine. These files are located in the VM's directory on a datastore. The following table will summarize and provide a quick reference and short description of the files that make up a virtual machine:

File

Example filename

Description

.vmx

<vmname>.vmx

Configuration file

.vmfx

<vmname>.vmfx

Additional configuration file

.vmtx

<vmname>.vmtx

Template file

.nvram

<vmname>.nvram

BIOS/EFI configuration

.vswp

<vmname>.vswp

Swap files

vmx-<vmname>.vswp

.log

vmware.log

Current log file

vmware-##.log

Old log file entries

.vmdk

<vmname>.vmdk

Virtual disk descriptor

-flat.vmdk

<vmname>-flat.vmdk

Data disk

-rdm.vmdk

<vmname>-rdm.vmdk

Raw device map file

-delta.vmdk

<vmname>-delta.vmdk

Snapshot disk

.vmsd

<vmname>.vmsd

Snapshot description data

.vmsn

<vmname>.vmsn

Snapshot state

.vmss

<vmname>.vmss

Suspend file

Depending on the state and configuration of the virtual machine, not all files may be present in the virtual machine directory.

Let's explore these virtual machine files in more detail.

Configuration files

The .vmx file describes the current configuration information and hardware settings for the VM. This can contain a large variety of information regarding the virtual machine, to include its specific virtual hardware configuration (amount of RAM, NIC settings, CD-ROM information, parallel/serial port information, and so on), as well as its advanced resource and power settings, VMware tools options, and so forth. It is possible to make changes and directly edit this file; however, do this at your own risk. Generally, it is recommended to have a backup of this file first and to not edit until recommended by VMware support.

The .vmx file is a plain-text file that functions as the structural definition of the VM. The .vmx file can be copied from the datastore and opened using a program that supports creation and saving of files using UTF-8 encoding, such as WordPad. The following excerpt shows an example of a .vmx file for a virtual machine named ExampleVM:

.encoding = "UTF-8"
config.version = "8"
virtualHW.version = "10"
nvram = "ExampleVM.nvram"
pciBridge0.present = "TRUE"
svga.present = "TRUE"
pciBridge4.present = "TRUE"
pciBridge4.virtualDev = "pcieRootPort"
pciBridge4.functions = "8"
pciBridge5.present = "TRUE"
pciBridge5.virtualDev = "pcieRootPort"
pciBridge5.functions = "8"
pciBridge6.present = "TRUE"
pciBridge6.virtualDev = "pcieRootPort"
pciBridge6.functions = "8"
pciBridge7.present = "TRUE"
pciBridge7.virtualDev = "pcieRootPort"
pciBridge7.functions = "8"
vmci0.present = "TRUE"
hpet0.present = "TRUE"
displayName = "SampleVM"
extendedConfigFile = "ExampleVM.vmxf"
virtualHW.productCompatibility = "hosted"
memSize = "384"
sched.cpu.units = "mhz"
powerType.powerOff = "soft"
powerType.suspend = "hard"
powerType.reset = "soft"
scsi0.virtualDev = "lsilogic"
scsi0.present = "TRUE"
ide1:0.deviceType = "cdrom-image"
ide1:0.fileName = "/vmfs/volumes/5099c3c8-d8fe7ee8-2961-005056903273/win2k3srvsp2.iso"
ide1:0.present = "TRUE"
floppy0.startConnected = "FALSE"
floppy0.clientDevice = "TRUE"
floppy0.fileName = "vmware-null-remote-floppy"
ethernet0.virtualDev = "e1000"
ethernet0.networkName = "Production"
ethernet0.addressType = "vpx"
ethernet0.generatedAddress = "00:50:56:bc:c0:47"
ethernet0.present = "TRUE"
scsi0:0.deviceType = "scsi-hardDisk"
scsi0:0.fileName = "ExampleVM.vmdk"
scsi0:0.present = "TRUE"
guestOS = "winnetenterprise"
toolScripts.afterPowerOn = "TRUE"
toolScripts.afterResume = "TRUE"
toolScripts.beforeSuspend = "TRUE"
toolScripts.beforePowerOff = "TRUE"
uuid.bios = "42 3c 4c d6 12 1e 5e c2-a4 a3 b6 89 95 9f 7a 75"
vc.uuid = "50 3c 6f a7 75 fb 68 7c-d1 42 df f7 f8 9b f5 f2"
chipset.onlineStandby = "FALSE"
sched.cpu.min = "0"
sched.cpu.shares = "normal"
sched.mem.min = "0"
sched.mem.minSize = "0"
sched.mem.shares = "normal"
sched.swap.derivedName = "/vmfs/volumes/5099c3c8-d8fe7ee8-2961-005056903273/ExampleVM/ExampleVM-7f1e3e76.vswp"
uuid.location = "56 4d 9b 08 ee d9 6c e2-ab 67 3a dc 63 16 cb fe"
replay.supported = "FALSE"
replay.filename = ""
scsi0:0.redo = ""
pciBridge0.pciSlotNumber = "17"
pciBridge4.pciSlotNumber = "21"
pciBridge5.pciSlotNumber = "22"
pciBridge6.pciSlotNumber = "23"
pciBridge7.pciSlotNumber = "24"
scsi0.pciSlotNumber = "16"
ethernet0.pciSlotNumber = "32"
vmci0.pciSlotNumber = "33"
vmci0.id = "-1784710539"
hostCPUID.0 = "0000000b756e65476c65746e49656e69"
hostCPUID.1 = "000106a50002080080b822291fabfbff"
hostCPUID.80000001 = "00000000000000000000000128100800"
guestCPUID.0 = "0000000b756e65476c65746e49656e69"
guestCPUID.1 = "000106a500010800809822010fabbbff"
guestCPUID.80000001 = "00000000000000000000000128100800"
userCPUID.0 = "0000000b756e65476c65746e49656e69"
userCPUID.1 = "000106a500020800809822010fabbbff"
userCPUID.80000001 = "00000000000000000000000128100800"
evcCompatibilityMode = "FALSE"
vmotion.checkpointFBSize = "4194304"
cleanShutdown = "TRUE"
softPowerOff = "FALSE"
ide1:0.startConnected = "TRUE"
toolsInstallManager.lastInstallError = "0"
tools.syncTime = "FALSE"
tools.remindInstall = "FALSE"
toolsInstallManager.updateCounter = "1"
unity.wasCapable = "FALSE"

Reading through this file gives us important information regarding the configuration of the virtual machine. Here are a few examples:

  • The VM's configured guest operating system can be derived from the guestOS line.

  • Based upon the memsize line, it is known that the VM was configured for 384 MB of memory.

  • The virtual machine only has one network adapter configured for the VM network port group based on the ethernet0 lines.

  • The virtual machine's vNIC has a MAC address of 00:50:56:bc:c0:47, specified by the ethernet0.generatedAddress line.

A virtual machine's .vmx file is most commonly edited to modify the MAC address so that it matches the effective MAC address set within the guest operating system.

The .vmx file is extremely important to the virtual machine. However, keep in mind that it only structurally defines the VM's virtual hardware composition. It does not hold any actual data from the guest OS running within the VM. The virtual machine's data is stored in its virtual disk file. Here is an overview of the configuration and BIOS files:

  • .vmtx: When a virtual machine is converted to a template, the virtual machine configuration file (.vmx) is replaced by the template configuration file (.vmtx).

  • .nvram: This is generally a fairly small file that contains the BIOS settings that the VM uses upon boot. This is similar to how a physical server that has a BIOS chip allows hardware configuration options. The virtual BIOS settings, contained in the .nvram file, can be accessed by pressing F2 when the virtual machine is powered on.

Swap files

The .vswp file is created when the virtual machine is powered on. The size of the .vswp file is equal to that of a configured memory, unless there is a reservation. When a memory reservation is configured for a VM, then the .vswp file size would equal the configured memory size minus the memory reservation. This file is used as a last resort when the hypervisor is reclaiming physical memory from its virtual machines, due to contention. Memory reclamation techniques are discussed in Chapter 6, Virtual Machine Performance and Resource Allocation.

Looking at the previous table, you may have noticed the vmx-<vmname>.vswp file. This file is for the overhead memory created for a VM, a new feature in vSphere 5.x. Historically, this memory overhead was not swappable. Though there was a memory reservation to back this, the entire address space did not actually have to reside in memory. This file helps to reduce the reservation requirements for virtual machines.

Virtual disks

The following are some of the virtual disk files:

  • .vmdk: Virtual disk descriptor, which holds information such as the size and disk geometry of the virtual disk, information that makes the VM believe it has a real hard disk and not files on a datastore. Such information includes the virtual disk's adapter type, drive sectors, heads, and cylinders. This descriptor file also contains a pointer to the larger data file for the virtual disk or the -flat.vmdk file. An example of this information is demonstrated in the following screenshot:

  • -flat.vmdk: This file actually contains the virtual disk's data. This is created by default when a virtual hard drive is added to a virtual machine that is not using the Raw Device Mapping (RDM) option. When created as a thick provisioned disk, it will be sized approximately to what was specified in the creation wizard. The different disk provisioning types will be discussed in Chapter 2, Creating a Virtual Machine Using the Wizard.

  • -rdm.vmdk: This is the mapping file for the Raw Device Mapping (RDM) option, managing the RDM device's mapping data. The virtual machine isn't aware of this since the mapping file is presented to the ESXi host as a traditional disk file and available for normal filesystem operations. The storage virtualization layer presents the mapped device as a virtual SCSI device to the VM. An –rdm.vmdk file exists for each RDM configured for the virtual machine. RDMs will be discussed in more detail in Chapter 2, Creating a Virtual Machine Using the Wizard and Chapter 10, Virtual Machine Design.

Snapshot files

The following are the snapshot files:

  • -delta.vmdk: These files are only used when creating snapshots. When a snapshot is created, the original –flat.vmdk file is no longer written to; it becomes read only. All changes that are written to the virtual disk are now being written to the –delta.vmdk files instead. Due to the fact that these –delta.vmdk files are bitmaps of changes made to a virtual disk, the –delta.vmdk file cannot exceed the size of the original –flat.vmdk file. A –delta.vmdk file is created for each snapshot that is generated. These –delta.vmdk files are updated in 16 MB increments as changes are written to the virtual disk.

  • .vmsd: This file is a snapshot descriptor that contains information regarding which files are used by each snapshot, description, display name, and any associated UIDs. There is only one .vmsd file per virtual machine, regardless of how many snapshots the virtual machine has. This file is updated each time a new snapshot is created or a snapshot is deleted.

  • .vmsn: This file stores the virtual machine's state at the time the snapshot was taken. The size of this file varies depending on whether the option to include the VM's memory state was selected during snapshot creation. A separate .vmsn file will be created for each snapshot and will automatically be removed when the snapshot is deleted.

Other files

Let's take a look at some other files:

  • .vmss: This file is used when a virtual machine is suspended so as to preserve the VM's memory contents; it is only present when the VM is suspended. When the virtual machine is resumed from the suspended state, it can start again right from where it left off. The contents of this file are written back to the ESXi host's physical memory when the virtual machine is brought out of a suspended state; however, the file will not be automatically deleted until the VM is powered off. This file will be approximately the same size as the configured memory for the virtual machine, unless memory contention is present.

  • .log: Log files are created in order to log information regarding the virtual machine, typically used during troubleshooting efforts. The current log file is always named vmware.log, and by default up to six older log files will be retained. These older log files will have a number appended at the end of their names, which will be updated with each file (vmware-2.log).

Viewing virtual machine files

A virtual machine's files can either reside on a VMFS or a NFS datastore. The vSphere Client or the vSphere Web Client can be used to browse the datastore and display a virtual machine's files.

Using the vSphere Client

In order to figure out which datastore the VM resides on and browse the datastore by performing the following steps:

  1. First select the virtual machine in the inventory.

  2. On the VM's Summary tab, there is a Resources pane that lists all the datastores being used by the selected VM.

  3. Right-click on a datastore and select Browse Datastore... from the available options.

    This is demonstrated in the following screenshot:

This process opens the Datastore Browser, which is a handy tool to quickly display the contents of any datastore. The virtual machine's files can be displayed by selecting the VM's directory, as shown in the following screenshot:

Note

The Datastore Brower shows that the virtual disk consists of only a single file, the .vmdk file. This is not indicative of reality; there are actually at least two files that make up the virtual disk, the .vmdk and –flat.vmdk files.

Another option in the vSphere Client is Storage Views; to access this option, perform the following steps:

  1. Select the VM in the inventory and then the Storage Views tab.

  2. There is a drop-down menu towards the left-hand side, click on it and select Show All Virtual Machine Files.

This is shown in the following screenshot:

Notice that the –flat.vmdk file is displayed in this view. This is the only view in the vSphere Client where the –flat.vmdk file is shown. All other views show only the .vmdk file.

Using the vSphere Web Client

If the vSphere Web Client is installed, then the virtual machine files may also be viewed using it. This view is the vSphere Web Client equivalent to the vSphere Client's Datastore Browser. Once the vSphere Web Client is launched:

  1. Browse to the Datastore and Datastore Cluster view.

  2. Once in this view, select the datastore that the virtual machine resides on in the inventory pane.

  3. From there, go to the Manage tab and select the Files button.

  4. The datastore directories will be listed on the left-hand side. Select the virtual machine; the results will look similar to what is displayed in the following screenshot. Note that the –flat.vmdk file is not shown:

Using command line

Alternatively, the files can be displayed via a command line. Ensure SSH is enabled on the ESXi host that the virtual machine is located on and use an SSH client, such as PuTTy, to establish a connection. For steps on how to enable SSH, check http://vmware.com/kb/1017910. Navigate to the virtual machine's directory and use the ls –l command to view the files.

An example of the output from using the ls –l command, after navigating to the VM's directory, is shown in the following screenshot:

VMware Tools


VMware Tools is a utility suite that enhances the performance of a virtual machine's guest OS. If VMware Tools is not installed in the guest operating system, the guest will be lacking in some important functionality. The VMware Tools utility improves virtual machine management by replacing the generic OS drivers with VMware drivers optimized for virtual hardware. The following components are included after the installation of VMware Tools:

  • The VMware Tools service

  • VMware Tools device drivers

  • The VMware user process

  • VIX

The VMware Tools service passes information between guest operating systems and the ESXi host; service starts when the guest OS boots. This runs as a vmtoolsd.exe program in Windows, vmware-tools-daemon in Mac OS X, and vmtoolsd in Solaris, FreeBSD, and Linux guest operating systems.

This service can run scripts that help automate repetitive guest operating system operations. Synchronization of the guest operating system time with the time on the ESXi host (with the exception of Mac OS X) can be configured with VMware Tools, though this is not necessarily recommended. Another benefit is the ability to move the mouse cursor freely between a Windows guest operating system in the VM and the vSphere Client (otherwise, Ctrl + Alt must be pressed in order to release the cursor from the VM console). Windows operating systems have the ability to quiesce snapshots used by certain backup operations provided by the service. VMware Tools also provides the process that sends heartbeats to VMware products to indicate that the guest operating system is running.

VMware Tools device drivers refine mouse operations and improve performance of networking, sound, and graphics. The guest OS will determine which drivers are installed with VMware Tools. The following device drivers can be included with VMware Tools:

Driver

Description

SVGA driver

Replaces the default VGA driver (640 x 480 resolution and 16-color graphics), enabling 32-bit displays, high display resolution, and faster graphics performance. Windows OSes that are Vista or later will use the VMware SVGA 3D driver.

SCSI driver

The VMware Paravirtual SCSI driver is included with VMware Tools for use. Other storage adapter drivers are bundled with the OS or are available via third-party vendors.

Paravirtual SCSI driver

High performance storage adapter that can produce greater throughput and lower processor utilization. This is best suited for a VM with an application that produces a very high amount of I/O throughput.

VMXNET NIC drivers

When installed, the VMXNET family of adapters can replace the default emulated networking drivers. These paravirtualized VMXNET adapters improve network performance and increase features.

Mouse driver

Improves mouse performance.

Audio driver

Required for many Windows OSes.

vShield Endpoint

When using vShield, a custom VMware Tools installation can install the vShield Endpoint Thin Agent component. vShield Endpoint offloads antivirus scans to the hypervisor without a large agent.

ThinPrint driver

Enables virtual printing for Windows VMs; printers will be listed in the guest OS that are added to the OS on the client or host.

Memory control driver

Used for efficient memory allocation between virtual machines, commonly called the balloon driver.

Modules and drivers for support of automatic virtual machine backups

Allows for third-party, vSphere integrated backup software to create application consistent snapshots. The virtual machine's disks are quiesced and certain processes are paused during the snapshot process. The Volume Shadow Copy Services (VSS) for Windows Server 2003 or newer, and the Filesystem Sync driver for older Windows OSes are installed.

VMCI and VMCI Sockets drivers

The Virtual Machine Communication Interface driver allows for efficient and fast communication between VMs on the same ESXi host.

The VMware user process starts when a user logs in to a Windows guest OS or starts a desktop environment session in Linux. The process' program file is called vmtoolsd.exe on Windows guest OSes and vmusr for FreeBSD, Solaris, and Linux operating systems. This allows for copy-and-paste interaction between the guest operating system and the vSphere Client, matching the screen display resolution of the guest with that of the vSphere Client.

VIX support is provided for using the VMware VIX API for guest operating system-bound API calls. The VIX API allows for the automation of virtual machine operations on the ESXi platform.

Summary


A vSphere administrator needs to understand virtual machine concepts before creating virtual machines. A virtual machine is a set of virtual hardware presented to a guest operating system whose characteristics are determined by a set of files. There are multiple VMware file types that are associated with and make up a virtual machine and are located in the VM's directory on a datastore. These files include the .vmx, .nvram, .vswp, .vmdk, -flat.vmdk, and .log files. Each virtual machine is equipped with virtual hardware and devices, such as one or more virtual CPUs, memory, video cards, IDE devices, SCSI devices, DVD/CD-ROM, parallel and serial ports, and network adapters, that provide the same functionality as physical hardware. Once the administrator understands that the virtual hardware is available, the next step is to learn how it can be configured. VMware Tools is a utility suite that enhances the performance of a virtual machine's guest OS. VMware Tools should be installed in every virtual machine to ensure the virtual machines aren't lacking in any functionality.

The next chapter will discuss how to create a virtual machine using the wizard and other associated configuration options.

Left arrow icon Right arrow icon

What you will learn

  • Understand virtual machine concepts
  • Create a virtual machine using the wizard
  • Understand other ways to provision virtual machines
  • Discover advanced virtual machine settings
  • Manage multitiered applications with vApps
  • Migrate and monitor your virtual machines
  • Balance resource utilization and availability
  • Optimize virtual machine performance and resource allocation

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Mar 21, 2014
Length: 326 pages
Edition :
Language : English
ISBN-13 : 9781782172185
Tools :

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing

Product Details

Publication date : Mar 21, 2014
Length: 326 pages
Edition :
Language : English
ISBN-13 : 9781782172185
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
€18.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
€189.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts
€264.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total 48.99
vSphere Virtual Machine Management
€48.99
Total 48.99 Stars icon
Banner background image

Table of Contents

10 Chapters
Virtual Machine Concepts Chevron down icon Chevron up icon
Creating a Virtual Machine Using the Wizard Chevron down icon Chevron up icon
Other Ways to Provision a Virtual Machine Chevron down icon Chevron up icon
Advanced Virtual Machine Settings Chevron down icon Chevron up icon
Managing Multitiered Applications with vApps Chevron down icon Chevron up icon
Virtual Machine Performance and Resource Allocation Chevron down icon Chevron up icon
Monitoring Virtual Machines Chevron down icon Chevron up icon
Migrating Virtual Machines Chevron down icon Chevron up icon
Balancing Resource Utilization and Availability Chevron down icon Chevron up icon
Virtual Machine Design Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Half star icon 4.5
(4 Ratings)
5 star 50%
4 star 50%
3 star 0%
2 star 0%
1 star 0%
vNelsonTX May 01, 2014
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Ask anyone in this industry and they will tell you those pivotal moments in their careers when they were inspired, mentored, coached by a select few that sling-shot them to great times. I have been fortunate to have several of those people that I got to work with or mentored by that have pushed me in the right direction in my career. I met Rebecca Fitzhugh while attending my vSphere 5.1 Install, Configure and Manage required classroom training in 2012. She was a delight to have as a teacher not only because of her vast knowledge on the topic of vSphere and vCenter, but also because she taught more than the manual and showcased real world scenarios, that we all know so well aren’t normally covered in these types of classes although VMware does a better job than other companies! At the conclusion of the class we exchanged information knowing that there would be opportunities to network in the future. Fast forward two years, Rebecca and I continue to network and she pushes me to pursue higher-level learning from VMware. Because of her suggestions, I have attained my VCA-Cloud, VCA-WM, VCA-DCV, VCP-DCV and VCP-DT. I am also currently studying for my VCAP-DTA and DCA. She truly has been one of those people that have inspired me to push further in my career and reinforce good values when working with my clients.Rebecca approached me at VMworld 2013 in San Francisco about a book she was writing about vSphere Virtual Machines, I was intrigued about this great opportunity for her and pressed her to keep me in the loop should an opportunity come up where I could partially return the favor for the knowledge she gave me. I am proud to be writing this review for her, because I know the knowledge that is in this book has already been put to use by me and will be by countless others. The book itself comprises of 326 pages and 10 chapters and is a nice balance of introduction, technical and deep dive with regards to vSphere VM’s.The book covers a lot of ground for all aspects of a VMware Admin from new to experienced. The author gives a thorough explanation of what a virtual machine is and the components that make one up, how to create virtual machines, provisioning, creating templates and how to configure resource pools. This is a great book for any admin that interacts with VMware vSphere and vCenter. I particularly appreciated the fact that most of the concepts in this book are current as of vSphere and vCenter 5.5. I highly recommend this book for any die-hard VMware person or someone brand new to the software suite. Grab a copy today and see for yourself!
Amazon Verified review Amazon
Water Donkey Jun 26, 2014
Full star icon Full star icon Full star icon Full star icon Full star icon 5
The book is written well and is succinct in it's delivery of the subject matter. It serves as a phenomenal desk reference to the vSphere administrator who is responsible for managing an inherited brownfield deployment. The book is also of service to any administrator who may one day be responsible for an upgrade or greenfield deployment, as it provides solid principles upon which a foundation for building VMs with proper resource allocation.Solid index for reference, and well considered table of contents with great explanations of features and why they are relevant to the administrator (instead of just explaining a feature and mentioning how it's configured).
Amazon Verified review Amazon
Jones Apr 22, 2014
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
I found this book extremely helpful and enormously useful. Each and every aspect of vSphere management that I needed to have personally explained from initial setup, and deployment, to management and techniques that have found their way into every day virtual machine management, utilization, upkeep and deployment. While I have utilized a hand full of the features in machine management, this book does a very good job in preparing me to use this powerful tool set for many years to come. Aspects that are covered include, virtual machine concepts, how, when, what, and why they are utilized, configuration and subsequent management, the tools that would be included, such as alternate provisioning methodology and machine conversion. Allocation of resources is covered as well as performance aspects, each subject area is well covered and throughly explained. I will be using this book for several years to come, it enabled me to solve these issues, one I was able to utilize the information in order obtain an understanding to impress an prospective client, and I was able rebuild a vSphere server completely and was happy with my results.
Amazon Verified review Amazon
Chris Hildebrandt Jun 23, 2014
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
Any more everyone is putting out VMware books and it kind of hard to sift out the good and the bad ones. Most of them cover all the same topics but do not go into detail. But I have to say I found good use out of this book. They covered all the major areas. They did a good job of covering from beginning to end deployment. They offer some good management tips. I think the author did a wonderful job on this book. I can see myself using this book for some time to come.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is included in a Packt subscription? Chevron down icon Chevron up icon

A subscription provides you with full access to view all Packt and licnesed content online, this includes exclusive access to Early Access titles. Depending on the tier chosen you can also earn credits and discounts to use for owning content

How can I cancel my subscription? Chevron down icon Chevron up icon

To cancel your subscription with us simply go to the account page - found in the top right of the page or at https://subscription.packtpub.com/my-account/subscription - From here you will see the ‘cancel subscription’ button in the grey box with your subscription information in.

What are credits? Chevron down icon Chevron up icon

Credits can be earned from reading 40 section of any title within the payment cycle - a month starting from the day of subscription payment. You also earn a Credit every month if you subscribe to our annual or 18 month plans. Credits can be used to buy books DRM free, the same way that you would pay for a book. Your credits can be found in the subscription homepage - subscription.packtpub.com - clicking on ‘the my’ library dropdown and selecting ‘credits’.

What happens if an Early Access Course is cancelled? Chevron down icon Chevron up icon

Projects are rarely cancelled, but sometimes it's unavoidable. If an Early Access course is cancelled or excessively delayed, you can exchange your purchase for another course. For further details, please contact us here.

Where can I send feedback about an Early Access title? Chevron down icon Chevron up icon

If you have any feedback about the product you're reading, or Early Access in general, then please fill out a contact form here and we'll make sure the feedback gets to the right team. 

Can I download the code files for Early Access titles? Chevron down icon Chevron up icon

We try to ensure that all books in Early Access have code available to use, download, and fork on GitHub. This helps us be more agile in the development of the book, and helps keep the often changing code base of new versions and new technologies as up to date as possible. Unfortunately, however, there will be rare cases when it is not possible for us to have downloadable code samples available until publication.

When we publish the book, the code files will also be available to download from the Packt website.

How accurate is the publication date? Chevron down icon Chevron up icon

The publication date is as accurate as we can be at any point in the project. Unfortunately, delays can happen. Often those delays are out of our control, such as changes to the technology code base or delays in the tech release. We do our best to give you an accurate estimate of the publication date at any given time, and as more chapters are delivered, the more accurate the delivery date will become.

How will I know when new chapters are ready? Chevron down icon Chevron up icon

We'll let you know every time there has been an update to a course that you've bought in Early Access. You'll get an email to let you know there has been a new chapter, or a change to a previous chapter. The new chapters are automatically added to your account, so you can also check back there any time you're ready and download or read them online.

I am a Packt subscriber, do I get Early Access? Chevron down icon Chevron up icon

Yes, all Early Access content is fully available through your subscription. You will need to have a paid for or active trial subscription in order to access all titles.

How is Early Access delivered? Chevron down icon Chevron up icon

Early Access is currently only available as a PDF or through our online reader. As we make changes or add new chapters, the files in your Packt account will be updated so you can download them again or view them online immediately.

How do I buy Early Access content? Chevron down icon Chevron up icon

Early Access is a way of us getting our content to you quicker, but the method of buying the Early Access course is still the same. Just find the course you want to buy, go through the check-out steps, and you’ll get a confirmation email from us with information and a link to the relevant Early Access courses.

What is Early Access? Chevron down icon Chevron up icon

Keeping up to date with the latest technology is difficult; new versions, new frameworks, new techniques. This feature gives you a head-start to our content, as it's being created. With Early Access you'll receive each chapter as it's written, and get regular updates throughout the product's development, as well as the final course as soon as it's ready.We created Early Access as a means of giving you the information you need, as soon as it's available. As we go through the process of developing a course, 99% of it can be ready but we can't publish until that last 1% falls in to place. Early Access helps to unlock the potential of our content early, to help you start your learning when you need it most. You not only get access to every chapter as it's delivered, edited, and updated, but you'll also get the finalized, DRM-free product to download in any format you want when it's published. As a member of Packt, you'll also be eligible for our exclusive offers, including a free course every day, and discounts on new and popular titles.