Setting up your Virtual Machine for VMware



Setting up your Virtual Machine on VMware

Hugh C. Lauer(

Adjunct Professor

Worcester Polytechnic Institute

For this course, each student will need a virtual machine on which to build, modify, and test Linux kernels. Project assignments require you to learn how to build a new version of the kernel, to add new service calls to the kernel, and to create a message system to transmit messages among Linux processes using the facilities of the kernel. This document describes how to set up your virtual machine on your personal laptop or desktop computer — VMware Workstation, VMware Fusion, or the free VMware Player.

A separate document describes how to set up and run your virtual machine on a new server system known as the Virtual Fossil Server. Instructions to do so can be found here:– .doc, pdf.

Virtual Machines

A virtual machine is an application program capable of simulating a computer system with enough fidelity and performance to mimic the actual hardware. The virtual machine concept originated in the 1960s, and it has now matured to the point where virtual machines are routinely used in a wide variety of commercial and organizational settings.

Two important terms in virtual machine technology are host and guest.

• The host is the hardware and operating system on which the virtual machine application runs — e.g., your own computer, a laboratory computer, or a departmental or corporate server. The host operating system is irrelevant, so long as it supports the virtual machine application. Sometimes the host system has no formal operating system of its own and, instead, runs the virtualization application directly on “bare hardware.” In this case, the virtualization application is called a hypervisor.

• The guest is the simulated computer, which runs its own operating system and set of applications — e.g., Linux running on top of Windows or Mac-OS.

The virtual machine application uses the host processors to simulate the guest processors, and it uses files on the host system to simulate the disks and RAM of the guest system. It also connects some host resources directly to the guest system — e.g., the host’s CD or DVD drive or a USB flash drive when it is plugged into the host system.

A goal of this Operating System course is to provide experience in working directly with the inner layers of a real, widely used operating system. You will be exposed both to the breadth and depth of such an operating system and also to many of its gory details. In order to do this, a safe place must be provided for you to work — a place where you can make mistakes, crash your operating system, corrupt disks and data structures, etc., without harming anyone else and even without harming your own, working computer.

The virtual machine provides this kind of environment. For this course, we provide a dual processor virtual machine with OpenSUSE Linux version 11.4 already installed.

VMware Workstation, Player, and Server

This course uses virtual machine applications provided by VMware, Inc. VMware is a company that makes and sells virtualization systems for commercial and scientific applications.

VMware Workstation is a virtualization application designed for Windows and Linux personal computers. It can be used to create new virtual machines and to run existing virtual machines. It supports multiple processors, multiple disks, network connections, and a variety of peripheral devices common to modern PCs. It includes the ability to take snapshots of a virtual machine and to roll the state of a virtual machine back to one of its snapshots. It also includes the ability to clone a virtual machine — i.e., to make almost an exact copy of it.[1]

VMware Player is a freeware subset of VMware Workstation that is designed to run virtual machines that were created under some other VMware system. It does not have all of the capabilities of VMware Workstation — particularly the ability to take snapshots and roll back to them. However, it is free, and it is adequate for the purposes of this course.

VMware Fusion is a similar product for the Mac, but I have never tried to use it. Therefore, there may be idiosyncrasies about this virtualization platform that I am unaware of. VMware also makes a number of server products, none of which have been adapted to this course.[2]

Installing your virtual machine

There are three parts to setting up your virtual machine:–

• Copy the course version of the virtual machine to a hard drive on your host system;

• Edit or adjust the properties of your virtual machine as needed; and

• Boot the virtual machine for the first time, connect it to the network, and create an identity for yourself

Obviously, you may recreate your virtual machine often as you need to. In particular, if you really mess up, the easiest thing may be to throw it away and install another.

Download and install your virtual machine

Download the zip file from the following URL:–



Note that this file is about 1.5 gigabytes. It will download fairly quickly on campus, but it could take a very long time to off-campus locations with slow network service.[3] Unzip this folder into a suitable place on your hard drive. Please remember that the unzipped files will eventually grow to about 16 gigabytes on your host machine. The unzipped folder should look something like Figure 1 below:–

[pic]

Figure 1

The most important file is the VMware virtual machine configuration file, which is highlighted in the figure. This is a text file describing all of the attributes of the virtual machine and its component files. You can open it in a text editor such as Notepad and examine its contents. However, that should not normally be necessary. Also included in this folder are a set of files to simulate the hard drive of the guest system; each can grow to 2 gigabytes. Note that when the guest system is running, several additional files are created, along with a lock folder to prevent the virtual machine from being opened more than once concurrently. None of these are included in the zipped folder but instead are created on the fly.

Before you can use your virtual machine, you need to acquire and install VMware Player (Windows, Linux), VMware Workstation (Windows, Linux), and VMware Fusion (Macintosh).

You can download and install the free VMware Player from here:–



Other VMware products can also be found at the VMware download site. Most will require you to purchase, but free evaluation licenses are available for some and student discounts are readily available.

Caution: Do not attempt to start your virtual machine in VMware Player yet! First, read the next section about adjusting the properties of your virtual machine.

[pic]

Figure 2

Adjusting the Properties of your Virtual Machine

Several properties of your virtual machine that you may wish to change include:–

• The number of processors.

• The size of (simulated) RAM memory

• The type of networking — i.e., bridged vs. NAT

• Shared folders

• The CD/DVD drive

The size of the RAM memory and the type of networking can be changed when the virtual machine is running, but changes do not take effect until it is restarted. Shared folders can be added and deleted, and CDs or DVDs can be inserted, ejected, and/or mapped to image files while the virtual machine is running.

To make changes in VMware Player, start VMware Player from the Start Menu — i.e., do not double click on the configuration file of your virtual machine. Within VMware Player, select Open a Virtual Machine from the Home screen. You should see a screen like Figure 2 above.

Select Edit virtual machine settings to bring up the dialog box of Figure 3 below, in which you can change the properties of your virtual machine.

[pic]

Figure 3

If instead of VMware Player, you are using VMware Workstation or another VMware product, open the virtual machine by navigating to and double-clicking on the VMware virtual machine configuration file. This file has the extension .vmx, and is the name indicated in Figure 1. Double-clicking will start the VMware application and present you with a window like Figure 4 below. The information in the right panel of this window is similar to that of Figure 3.

[pic]

Figure 4

Number of Processors

If your host computer has only one processor, then VMware will refuse to run a guest system with more than that number. Edit the number of processors in Figure 3 or Figure 4 to change it to one processor. If you have more than two processors, you can increase the number assigned to the virtual machine

Size of RAM memory

By experience, we have found that the virtual RAM of the guest system should not exceed 50% of the host RAM. The default when this virtual machine was created is 1.5 gigabytes. You may increase it if you have enough host RAM. If your host system has less than three gigabytes of RAM, we suggest that you reduce the size of the virtual machine RAM. To make a change, double-click on the Memory line of Figure 3 or Figure 4 to open the control panel for RAM memory, jake the adjustment, and click Okay.

Bridged vs. NAT networking

There are two ways[4] in which your virtual machine can connect to the network:–

• Bridged networking means that your virtual machine looks like any other device on the network. It has its own IP address and its own MAC address, separate from the host system. It is completely indistinguishable from a hardware system with the same IP and MAC addresses.

• NAT means Network Address Translation.[5] It is a technique by which the VMware application on your host computer re-addresses every packet from and to your guest operating system so that those packets appear to the outside world as if they come from or go to the host itself. The virtual machine and guest operating system are completely invisible.

Normally, you would use bridged networking only on unsecured networks or networks for which you manage the security yourself — for example, your home network.

You are strongly encouraged to use NAT if are on a WPI wired or wireless network or if you are on some other network for which the administration controls, registers, and/or manages all computers and devices attached to it. However, if you do intend to use bridged networking on the WPI network, see the following URL:–



Your virtual machine as distributed with NAT networking by default. If you wish to change it, double-click on the Network Adapter line of the Hardware or Devices tab of Figure 3 or Figure 4 and change it in the control panel for network adapters.

Shared Folders

The OpenSUSE 11.4 operating system comes with open-vm-tools installed by default. This is an open source implementation of VMware Tools, which have been distributed by VMware for many years. Open-vm-tools comprise a number of modules, some loaded into the guest operating system kernel and others operating in the guest user space. These make the operation of the virtual machine and guest system more efficient — for example, the virtual display and network cards communicate via a private channel directly with the VMware application.

A very useful tool is the shared folder — i.e., a folder or directory of the host system that can be read and written by the guest operating system. You will use this a lot in this course! In the guest operating system, the shared folder is implemented by a special file system called the Host-Guest File System, or hgfs for short, which is part of open-vm-tools. A directory called

/mnt/hgfs

has been created for you in the guest operating system of your virtual machine. All shared folders appear within this directory as they are added in the host.

By default, sharing between host and guest is disabled whenever your clone or copy a virtual machine. You may have to enable it again explicitly for this course. Clicking the Options tab of Figure 3 or Figure 4, will bring up Figure 5 below. Select the Always Enabled button. In the Folders panel in the bottom part of this window, you can add and remove folders and change their properties. In particular, you can make them read-only or writable by the guest system.

Caution: I have not been able to make Shared Folders work with this recent version of Linux. I believe that there is some setting in the guest operating system that prevents the host-guest file system from being mounted, but I have not been able to find it. Other utilities indicate that the shared folders are, in fact, visible in the guest system. In particular, executing the command

/usr/bin/vmware-hgfsclient

in a command shell in the guest operating system will list them.

[pic]

Figure 5

In all versions of VMware, you may enable and disable shared folders at run time. This is equivalent to mounting and unmounting devices in your virtual machine. That is, if you enable shared folders, the list of folders in the Folders panel in the lower right of Figure 5 becomes the list of subdirectories of /mnt/hgfs. If you disable shared folders, they magically disappear from /mnt/hgfs. Moreover, you can add or remove individual host folders at run time, and they will magically appear or disappear as individual subdirectories of /mnt/hgfs.

CD-DVD device

The virtual machine for this course is distributed with a virtual DVD installed in its virtual CD-DVD drive, namely the distribution disk of OpenSUSE Linux 11.4. It is not anticipated that we will need it for this course, and you may safely ignore any error about the CD-DVD drive. At run time, you may also change the mapping of this drive to disk images (i.e., .iso files) in the host, to connect this virtual drive to a physical CD-DVD drive in the host, or to disconnect it altogether.

Starting your Virtual Machine for the first time

To start your virtual machine in VMware Player, click on Play Virtual Machine in Figure 2. If you are using VMware Workstation or another VMware application, click Power on this virtual machine in the Commands panel of Figure 4.

The next thing you should see is the following dialog box:–

[pic]

Figure 6

Be sure to select “I copied it.” The reason is that VMware fabricates a network MAC address from the path name of the VMware virtual machine configuration file. [6] VMware uses this path name to figure out whether it is dealing with the same virtual machine or a copy. Very, very bad things happen when two or more computers get onto the same network with the same MAC address. By selecting “I copied it,” VMware changes the MAC address to something different (and hopefully unique, at least within the scope of your network).[7]

Note 1: You won’t see this dialog if you cloned your virtual machine from the master virtual machine, for the simple reason that VMware already knows that it is a copy and has already changed the MAC address of its network adapter. Although you may experiment with cloning, it is not needed in the course.

Note 2: Later, if you open your virtual machine on a different PC from the one where you created it, you may get this message again. This time, select “I moved it” so that it keeps the same MAC address, thereby avoiding the need to reconfigure the network card (see below).

Next, you will see the boot screen of your virtual machine, as shown in Figure 7. In VMware Player, this screen will occupy the entire application window. In VMware Workstation and other VMware applications, it will occupy a panel of the window, or the entire window, depending upon your settings of the application.

[pic]

Figure 7

If you do nothing at this point, the virtual machine will boot the default option (Desktop -- openSUSE 11.4) after a brief timeout. The numbers after the operating system identification are the version of the kernel that we will be using this term.

In the future, you will need to control the boot options; do this by clicking in boot screen, then using the arrow keys to select the desired option before the timeout expires, and finally pressing Enter.

Note: You transfer the input focus of the mouse and keyboard to the virtual machine by clicking in its window or typing CTRL-G. You can return the input focus to the desktop by typing CTRL-ALT. If the input focus is in the wrong place, the virtual machine won’t hear you type and won’t notice you moving the mouse.

Once the focus is in the virtual machine, you may use the up and down arrows to select the booting option and Enter to invoke that booting option. You can also cancel the boot timeout by simply clicking the arrow keys. This will give you time, for example, to change settings in the VMware Player menu bar. There is a settable boot timer that controls how long SUSE Linux waits before booting the default option.

During booting, the screen may briefly change to a text console, and then it will eventually change to a GUI login interface resembling Figure 8. If you want to watch the Linux boot messages, type ESC when the input focus is in the virtual machine.

[pic]

Figure 8

This screen has been configured to be 1280-by-1024 pixels in size. If you wish it to take over the entire display (i.e., run in full-screen mode), press CTL-ALT-Enter. Later, if you wish to return it to a window of your VMware Player or VMware Workstation, press CTL-ALT-Enter again.

If the screen in Figure 8 is too large to fit into the VMware Player or VMware Workstation window, or if it is too large to fit on your monitor in full screen mode, you will see scrollbars. You may resize the virtual display to fit your own monitor or window later, after you have logged in (see below under Changing the Display Size).

When you are running your virtual machine in full-screen mode, a fragment of a menu bar appears at the top of the screen. This lets you access useful VMware commands at run time. For example, Figure 9 shows the menu bar for VMware Workstation. The “thumb tack” at the left of the menu bar locks it in place or allows it to retract upward from view. Figure 10 shows the corresponding menu bar from VMware Player.

[pic]

Figure 9

[pic]

Figure 10

In these menu bars, the VM or Virtual Machine pull-down menus contain various commands that allow you to change the settings of the virtual machines, modify the Shared Folders, connect host devices such as CD-DVD drives and USB devices to the virtual machine, etc. The menu items are equivalent to similar menu commands provided by VMware Workstation and VMware Player before the virtual machine is powered on. Also at the right of both menu bars are buttons to minimize, maximize, and close the guest.

Logging in

Your login ID is student. Your password this term is “CS-3013/502” (without the quotes). After you have logged in, you will be presented with a graphic desktop called KDE, the Linux Desktop Environment, shown below. This is the SUSE Linux equivalent of the Windows desktop, and it is used much the same way. In particular, note the little green “Gecko” icon in the lower left corner. This is functionally equivalent to the Start button in Windows. Click it to get a two-dimensional menu of program items and other commands.

[pic]

Figure 11

Note: In modern versions of Linux, you rarely, if ever, need to log in as root. Most of the time, you should log in as a non-privileged user and use the sudo command to invoke root privileges as needed. This avoids accidents that are typical in most system development environments. As a helpful reminder, KDE configures the user root with a distinctive desktop background that contains warning signs and images of bombs.

Note: After you have logged in, open-vm-tools will be automatically enabled. Then, the input focus will usually follow the mouse. That is, you can move the mouse out of the virtual machine and click in a normal desktop window and work there. You can then move the mouse back into the virtual machine, click, and work there.

Testing and/or fixing your network connection

It used to be the case that OpenSUSE Linux recorded the MAC address of its network adapters in some internal configuration file somewhere, and then it would look for devices with those particular MAC addresses at boot time. The unfortunate consequence is that when the MAC address changes as a result of cloning or copying the virtual machine, the OpenSUSE Linux kernel could not start the network adapter that it was looking for. With the current version of OpenSUSE Linux, this seems to no longer be a problem. However, it is worth testing the network connection before proceeding.

To do this, click on the Start button in the lower left corner of the KDE desktop. This will bring up a menu looking like the following:–

[pic]

Figure 12

Select the Terminal command to bring up a Linux command shell. Type the shell command

ip address

to display the internet addresses of this virtual machine. You should see something like the results in Figure 13, below. The “link/ether” line should be present and should display a valid internet address. If your virtual machine is using Network Address Translation (NAT), then it should be of the form 192.168.xx.yy. You should now be able to access the network, for example, via the web browser Firefox, which is preinstalled in your guest system.

[pic]

Figure 13

If you do not have a valid internet address or cannot access the network, see the Appendix of this document to fix the problem.

[pic]

Figure 14

Creating a user identity for yourself

It is helpful to create a user identity for yourself and to get rid of the student identity built into these virtual machines. (If you are part of a team, create an identity for each team member.) To create a user identity, invoke YaST, the system administration tool, [8] to configure the user and group settings. Click the Start button in the lower left corner, select the third submenu, labeled Computer as shown below, and select the YaST command, as shown below in Figure 14 above.

YaST will first ask you for the root password. This is CS-3013/502, the same as the password for the user student. It will then bring up the YaST window, shown in Figure 15 below.

[pic]

Figure 15

Select Security and Users from the left panel and User and Group Management from the right panel. Follow this GUI to create a new identity for yourself and/or to change passwords. We suggest that you use your WPI e-mail identity. Log out, and then log in with this new identity, and finally use YaST again to delete the student identity.

Changing the Display Size

It is a nuisance to try to work with a virtual display of the guest system that does not fit into a window or on the screen of the host system. If you wish to change the display size of the guest, invoke the Configure Desktop command from the Start menu of Figure 12. This brings up a window resembling Figure 16:–

[pic]

Figure 16

Select Display and Monitor in the Hardware section to tell KDE the size of the display. After you have selected and applied the new display size, click the option that says to make it the default.

Finally, select Application Appearance in the top section, which opens a window with a lot of options. Select Fonts from the left panel. This lets you set the font sizes for most of the window characteristics. Note especially the Force Fonts DPI pull-down menu near the bottom, which controls the number of pixels per inch. Setting this will help the font sizes to look like those sizes on the virtual display. Feel free to experiment with other settings in this tool.

Useful Features

You are now in a position to experiment with and explore your very own Linux system. You don’t have to use the Graphic User Interface, but it saves a lot of time and a long learning curve. You are also in a position to experiment with useful tools of VMware. This section discusses several of them.

Snapshots

A highly useful feature of VMware Workstation is the ability to take snapshots. This is accessed from the VM menu of the Workstation application (and also the menu bar at the top of the full-screen mode display). When you take a snapshot, VMware records the state of your virtual machine for future use. Later, after you have crashed or corrupted your disk beyond belief, you can restore it to a previous state by invoking the Snapshot command in the VM menu.

To make a snapshot, VMware makes a record of all of the disk blocks of the guest system. Any subsequent changes to any disk blocks are made to new copies. Later, to revert to a snapshot, the new copies of blocks are discarded and the original blocks are restored.[9] Conversely, if a snapshot is deleted, the copied blocks and original blocks are merged so that the appropriate state is preserved. VMware does this automatically for you, so you don’t have to keep track of it yourself. It is possible to have snapshots of snapshots, recursively, but it is not advisable because performance can suffer.

Unfortunately, snapshots are not available in VMware Player, and they only have limited capability in some other VMware products.

Suspending, Restarting, and Moving your Virtual Machine

Another highly useful feature of VMware is that you can suspend a virtual machine and resume it later. Simply use the Suspend sub-command of the Power command of the VM menu. Moreover, you can log out of the host machine, return later, log again, and resume your suspended virtual machine.

You can even suspend a virtual machine, move it to another host system, and resume it. You will get a dialog box of Figure 6 saying that it noticed that your machine is in a different place than before and asking if you copied or moved it. Respond to this dialog saying that you moved it, so that VMware does not gratuitously change the MAC address.

Shared Folders

Shared folders were discussed above. These are a very useful way of transferring files between host and guest — something that you will need to do often. For example, if you have files you want to save before you try out something potentially dangerous, copy them into a shared folder and the disable that particular folder. This way, the files will be protected in the host and will be safe, even if you crash the guest operating system, corrupt its disk, etc.

The one caveat is that shared folders are part of open-vm-tools, and open-vm-tools are tied to a particular version of the Linux kernel. If you modify and rebuild the kernel, the tools do not work with the modified kernel. Fortunately, they will resume working when you reboot the original kernel.[10]

Note: As noted above, I have not been able to make Shared Folders work with this version of OpenSUSE Linux. I have been able to make it work by uninstalling open-vm-tools and installing VMware’s proprietary tool set. However, this has caused other problems, including rendering the virtual machine unbootable after modifying the kernel. There will be an extra-credit option in the programming assignments for anyone who can make it work without install VMware’s proprietary tools.

As an alternative, I open a browser to my WPI e-mail account and mail files to myself, in order to preserve them outside the virtual machine. It is also possible to copy them to a USB flash drive, as described in the next section.

Note: Another feature of open-vm-tools is the ability to copy and paste between the host and guest system in both directions. I have not been able to make this work, either. However, the rest of the features of open-vm-tools seem to work okay.

USB flash drives

Your virtual machine and OpenSUSE Linux support the usual assortment of flash drives. If you plug in a USB device while the input focus is in the guest operating system, it will open in the guest or host system, depending up the settings of VMware Player and/or VMware Workstation. If it opens in the guest system, you can access the device from the KDE desktop by clicking on the Device Notifier button. This is located behind the up-arrow symbol immediately to the left of the time-of-day, at the far right end of the menu bar.

Sometimes, VMware gets into the act and brings up a dialog box asking whether you want to connect the device to the host or the guest. Answer the dialog appropriately. Also, if you particularly do not want a device connected to the guest, go to the Devices menu in the VMware Player menu bar or the Removable Devices command of the VM menu in VMware Workstation and manage the device there.

Fortunately, USB devices work in modified kernels, provided that the drivers have not been deleted.

Disaster Prevention

During the first few years when we used VMware virtual machines in Operating Systems courses, students stumbled on a number of idiosyncrasies that rendered their virtual machines totally inoperable, trapping their work inside. As we have refined this course, this kind of disaster occurs less and less frequently.

Nevertheless, it is always a good idea to back up your own work. The best way to do this is to copy the relevant files onto a USB flash drive or to a shared folder. From time to time, we have tried other methods of protecting students from lost work — particularly, configuring virtual machines with separate drives for the /home directory — but none of them has proven very practical.

Conclusion

That’s it. Enjoy your virtual machine. You are now ready for your first kernel project. When you are ready to take a break, you may power off your virtual machine by invoking the “leave” tab from the Start menu and selecting the appropriate option. You may also “Suspend” the virtual machine by simply exiting VMware Workstation.

Documentation

Documentation for VMware Workstation can be found here:–



Documentation about OpenSUSE Linux can also be found on-line at



and



This includes a getting started guide, a user’s manual, an administrator’s manual, and other information. Do not try to print these. Together, they are well over 1000 pages.

Appendix — Fixing the Network Connection

If your network connection does not work as indicated in Figure 13, you can fix it by doing the following. Invoke YaST to configure the network adapter for the new MAC address. Select Network Devices in the left panel, and then select Network Settings in the right panel. This will bring up the window of Figure 17.

[pic]

Figure 17

Select the device that is “Not configured” and click Edit. In the next window, accept the proposed settings and click Next. The Network Settings tool should reconfigure its devices and exit. Test your network again, as shown in Figure 13.

-----------------------

( Copyright 2011, Hugh C. Lauer. All rights reserved. Permission is given for use in courses at Worcester Polytechnic Institute, Worcester, Massachusetts.

[1] One crucial difference is that the network addresses of original and the clone will not be the same.

[2] A number of other virtualization platforms are also available. If you are intent on using one of them, please see the Professor for a virtual machine image. However, you are on your own for support.

[3] If download speed is a problem for you, it is suggested that you download the zip file to a flash drive using a public computer on campus and then physically carry it to your computer off campus.

[4] The third option, host networking, is used when you want to create a suite of virtual machines on the same host, all connected to each other but isolated from the outside world. We do not use it in this course.

[5] NAT is widely used in hubs and gateways for home and small business networks to isolate their IP addresses from those of the Internet.

[6] MAC addresses are the hardware addresses that Ethernet devices use to communicate with each other. MAC stands for “Media Access Code”.

[7] MAC addresses of network adapters are supposed to be globally unique, and each manufacturer (including VMware) is assigned a range of MAC addresses for its own products. Nevertheless, it is possible for network devices to masquerade as others by pretending to have MAC addresses other than their own. For example, cable modems do this often (in a controlled way).

[8] So far as I can tell, YaST stands for Yet another System Tool.

[9] VMware Workstation uses the exact same mechanism for “cloning” a virtual machine. Disk blocks of the original are preserved, and all changes to the original are made in copies of these blocks, while all changes to the cloned virtual machine are also made in separate copies. This lets the original and clone share common blocks, while letting each one diverge from the other.

[10] This is a welcome change from previous years, where we had to use the proprietary VMware Tools. In that case, the shared folders stopped working and would not work again without being recompiled.

-----------------------

CS-3013, Operating Systems

A-Term 2011

................
................

In order to avoid copyright disputes, this page is only a partial summary.

Google Online Preview   Download