| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|---|
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | 
|---|
| 3 | <head> | 
|---|
| 4 | <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | 
|---|
| 5 | <meta http-equiv="Content-Style-Type" content="text/css" /> | 
|---|
| 6 | <meta name="generator" content="pandoc" /> | 
|---|
| 7 | <title>Shared storage and migration</title> | 
|---|
| 8 | <style type="text/css">code{white-space: pre;}</style> | 
|---|
| 9 | <link rel="stylesheet" href="style.css" type="text/css" /> | 
|---|
| 10 | </head> | 
|---|
| 11 | <body> | 
|---|
| 12 | <div id="header"> | 
|---|
| 13 | <h1 class="title">Shared storage and migration</h1> | 
|---|
| 14 | </div> | 
|---|
| 15 | <div id="TOC"> | 
|---|
| 16 | <ul> | 
|---|
| 17 | <li><a href="#objectives"><span class="toc-section-number">1</span> Objectives</a></li> | 
|---|
| 18 | <li><a href="#create-vm"><span class="toc-section-number">2</span> Create VM</a></li> | 
|---|
| 19 | <li><a href="#ssh-into-vm"><span class="toc-section-number">3</span> ssh into VM</a></li> | 
|---|
| 20 | <li><a href="#suspend-and-resume"><span class="toc-section-number">4</span> Suspend and resume</a></li> | 
|---|
| 21 | <li><a href="#migrate"><span class="toc-section-number">5</span> Migrate</a><ul> | 
|---|
| 22 | <li><a href="#in-the-virsh-command-line"><span class="toc-section-number">5.1</span> In the virsh command line</a></li> | 
|---|
| 23 | <li><a href="#using-virt-manager-gui"><span class="toc-section-number">5.2</span> Using virt-manager GUI</a></li> | 
|---|
| 24 | </ul></li> | 
|---|
| 25 | <li><a href="#optional-exercises"><span class="toc-section-number">6</span> Optional exercises</a></li> | 
|---|
| 26 | </ul> | 
|---|
| 27 | </div> | 
|---|
| 28 | <h1 id="objectives"><a href="#objectives"><span class="header-section-number">1</span> Objectives</a></h1> | 
|---|
| 29 | <p>In this exercise, you will start up a VM with shared storage disk image, and then migrate it to another group's host, while it is still running.</p> | 
|---|
| 30 | <p>VM disk images have already been prepared, one for each of you, and are on a central class storage server.</p> | 
|---|
| 31 | <p>If you are working in pairs then</p> | 
|---|
| 32 | <ul> | 
|---|
| 33 | <li>group 1 has disk image 1 and 2</li> | 
|---|
| 34 | <li>group 2 has disk image 3 and 4</li> | 
|---|
| 35 | <li>...</li> | 
|---|
| 36 | <li>group N has disk image 2N-1 and 2N</li> | 
|---|
| 37 | </ul> | 
|---|
| 38 | <p>The nbd port number is then 20000 + the disk image number.</p> | 
|---|
| 39 | <p>Please do try to use the correct image and not connect to someone else's image; this will result in corruption if two VMs are using the same image at once. However in case of an accident it is very quick for the instructors to copy a clean disk image for you.</p> | 
|---|
| 40 | <h1 id="create-vm"><a href="#create-vm"><span class="header-section-number">2</span> Create VM</a></h1> | 
|---|
| 41 | <p>Both people in a pair have their own disk image, so they can work on this part independently.</p> | 
|---|
| 42 | <p>ssh into your group's host server - you should be logged in as the "nsrc" user, not as root.</p> | 
|---|
| 43 | <p>The disk image already exists, but you will still have to create a VM to attach the disk to.</p> | 
|---|
| 44 | <p>This time, you're going to do it using an XML file. Copy and paste the following XML into a file in your home directory, say "serverX.xml" where X is your disk image number.</p> | 
|---|
| 45 | <pre><code><domain type='kvm'> | 
|---|
| 46 | <name>serverX</name> | 
|---|
| 47 | <memory unit='KiB'>524288</memory> | 
|---|
| 48 | <currentMemory unit='KiB'>524288</currentMemory> | 
|---|
| 49 | <vcpu placement='static'>1</vcpu> | 
|---|
| 50 | <os> | 
|---|
| 51 | <type arch='x86_64' machine='pc-1.1'>hvm</type> | 
|---|
| 52 | <boot dev='hd'/> | 
|---|
| 53 | </os> | 
|---|
| 54 | <features> | 
|---|
| 55 | <acpi/> | 
|---|
| 56 | <apic/> | 
|---|
| 57 | <pae/> | 
|---|
| 58 | </features> | 
|---|
| 59 | <clock offset='utc'/> | 
|---|
| 60 | <on_poweroff>destroy</on_poweroff> | 
|---|
| 61 | <on_reboot>restart</on_reboot> | 
|---|
| 62 | <on_crash>restart</on_crash> | 
|---|
| 63 | <devices> | 
|---|
| 64 | <emulator>/usr/bin/kvm</emulator> | 
|---|
| 65 | <disk type='network' device='disk'> | 
|---|
| 66 | <driver name='qemu' type='raw'/> | 
|---|
| 67 | <source protocol='nbd'> | 
|---|
| 68 | <host name='s1.ws.nsrc.org' port='200XX'/> | 
|---|
| 69 | </source> | 
|---|
| 70 | <target dev='hda' bus='ide'/> | 
|---|
| 71 | <address type='drive' controller='0' bus='0' target='0' unit='0'/> | 
|---|
| 72 | </disk> | 
|---|
| 73 | <controller type='usb' index='0'> | 
|---|
| 74 | <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/> | 
|---|
| 75 | </controller> | 
|---|
| 76 | <controller type='ide' index='0'> | 
|---|
| 77 | <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/> | 
|---|
| 78 | </controller> | 
|---|
| 79 | <interface type='bridge'> | 
|---|
| 80 | <mac address='52:54:00:FF:00:XX'/> | 
|---|
| 81 | <source bridge='br-lan'/> | 
|---|
| 82 | <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/> | 
|---|
| 83 | </interface> | 
|---|
| 84 | <serial type='pty'> | 
|---|
| 85 | <target port='0'/> | 
|---|
| 86 | </serial> | 
|---|
| 87 | <console type='pty'> | 
|---|
| 88 | <target type='serial' port='0'/> | 
|---|
| 89 | </console> | 
|---|
| 90 | <input type='mouse' bus='ps2'/> | 
|---|
| 91 | <graphics type='vnc' port='-1' autoport='yes' listen='0.0.0.0'> | 
|---|
| 92 | <listen type='address' address='0.0.0.0'/> | 
|---|
| 93 | </graphics> | 
|---|
| 94 | <video> | 
|---|
| 95 | <model type='cirrus' vram='9216' heads='1'/> | 
|---|
| 96 | <address type='pci' domain='0x0000' bus='0x00' slot='0x02' function='0x0'/> | 
|---|
| 97 | </video> | 
|---|
| 98 | <memballoon model='virtio'> | 
|---|
| 99 | <address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/> | 
|---|
| 100 | </memballoon> | 
|---|
| 101 | </devices> | 
|---|
| 102 | </domain></code></pre> | 
|---|
| 103 | <p>Change three things:</p> | 
|---|
| 104 | <ul> | 
|---|
| 105 | <li>In <code><name>serverX</name></code>, change X to your disk image number</li> | 
|---|
| 106 | <li>In <code>port='200XX'</code>, change XX to your disk image number (01 upwards)</li> | 
|---|
| 107 | <li>In <code><mac address='52:54:00:FF:00:XX'/></code>, change XX to your disk image number as two decimal digits. (So disk image 40 becomes <code>52:54:00:FF:00:40</code>)</li> | 
|---|
| 108 | <li>Save the file</li> | 
|---|
| 109 | </ul> | 
|---|
| 110 | <p>Now define your virtual machine using the file you have created:</p> | 
|---|
| 111 | <pre><code>$ virsh define serverX.xml</code></pre> | 
|---|
| 112 | <p>If this is successful, you should see that it is present and be able to start it.</p> | 
|---|
| 113 | <pre><code>$ vish list --all | 
|---|
| 114 | $ virsh start --console serverX    # replace X with your disk image number</code></pre> | 
|---|
| 115 | <p>After around 10-15 seconds you should get a login prompt at the console. The username and password will be given to you in class.</p> | 
|---|
| 116 | <p>In this console session, type <code>ifconfig</code> to find out what IP address has been allocated to it:</p> | 
|---|
| 117 | <pre><code>$ ifconfig eth0</code></pre> | 
|---|
| 118 | <p>Write it down, then disconnect from the serial console (press ctrl and right-hand square bracket)</p> | 
|---|
| 119 | <p>Now you are back on your host server. Use these commands to show that your KVM process is running:</p> | 
|---|
| 120 | <pre><code>$ virsh list | 
|---|
| 121 | $ ps auxwww | egrep '(kvm|qemu-system)'</code></pre> | 
|---|
| 122 | <p>Look for <code>-name serverX</code> in the kvm command line, so you know it's yours.</p> | 
|---|
| 123 | <h1 id="ssh-into-vm"><a href="#ssh-into-vm"><span class="header-section-number">3</span> ssh into VM</a></h1> | 
|---|
| 124 | <p>Now using another ssh connection, e.g. another putty window, ssh directly to this running VM, using the IP address you just noted. Obviously this is using the same username/password that you were given before, as it's just a different way of connecting to the same VM.</p> | 
|---|
| 125 | <p>All the VMs start off as being identical, so make some changes to yours so that it is distinctive. For example:</p> | 
|---|
| 126 | <ul> | 
|---|
| 127 | <li>Type <code>sudo -s</code> to get a root shell</li> | 
|---|
| 128 | <li>Edit <code>/etc/hostname</code> to change the hostname to anything of your choice</li> | 
|---|
| 129 | <li>Edit <code>/etc/hosts</code> with the new hostname</li> | 
|---|
| 130 | <li>Create the file <code>/etc/motd.tail</code> containing a welcome message</li> | 
|---|
| 131 | <li>Type <code>service hostname start</code> to refresh the hostname</li> | 
|---|
| 132 | </ul> | 
|---|
| 133 | <p>If you then disconnect and reconnect your ssh client, you should see your welcome message and the new hostname in the prompt.</p> | 
|---|
| 134 | <p>Now you want to get the VM to do some visible work while you migrate it. Type the following command line:</p> | 
|---|
| 135 | <pre><code>$ while true; do date; sleep 0.5; done</code></pre> | 
|---|
| 136 | <p>This will make it display the current date and time twice per second, so you should see this scrolling up the screen. Leave it running.</p> | 
|---|
| 137 | <h1 id="suspend-and-resume"><a href="#suspend-and-resume"><span class="header-section-number">4</span> Suspend and resume</a></h1> | 
|---|
| 138 | <p>Just to prove that this is a running VM, now go back to your ssh session to the host server, while keeping the VM session window open so you can see the scrolling text.</p> | 
|---|
| 139 | <p>On the host server, type the following commands:</p> | 
|---|
| 140 | <pre><code>$ virsh suspend serverX | 
|---|
| 141 |  | 
|---|
| 142 | $ virsh resume serverX</code></pre> | 
|---|
| 143 | <p>The 'suspend' should stop the messages from the VM scrolling up the screen, and 'resume' should restart them. Leave the VM running and the messages scrolling up.</p> | 
|---|
| 144 | <h1 id="migrate"><a href="#migrate"><span class="header-section-number">5</span> Migrate</a></h1> | 
|---|
| 145 | <p>Now to migrate the virtual machine to another host. You will migrate to the next server numerically: those using vm1 will migrate their servers to vm2; those on vm2 will migrate their servers to vm3; and so on.</p> | 
|---|
| 146 | <p>This can be done either using the virsh command line, or the virt-manager GUI. Try the virsh command line first.</p> | 
|---|
| 147 | <h2 id="in-the-virsh-command-line"><a href="#in-the-virsh-command-line"><span class="header-section-number">5.1</span> In the virsh command line</a></h2> | 
|---|
| 148 | <p>In the host server ssh window:</p> | 
|---|
| 149 | <pre><code>$ virsh migrate --live --verbose serverX qemu+ssh://vmN.ws.nsrc.org/system</code></pre> | 
|---|
| 150 | <p>where X is your disk image number and N is your group number plus 1.</p> | 
|---|
| 151 | <p>You'll be prompted for the ssh password to the next machine.</p> | 
|---|
| 152 | <p>That's it. Your VM should still be running, but will be on a different host!</p> | 
|---|
| 153 | <p>To check, use:</p> | 
|---|
| 154 | <pre><code>$ virsh list | 
|---|
| 155 | $ ps auxwww | egrep '(kvm|qemu-system)'</code></pre> | 
|---|
| 156 | <p>on your host, and on the next group's host. (Ask them to do it for you, or carefully ssh into their host and do it)</p> | 
|---|
| 157 | <p>From there, you can get them to migrate it back again:</p> | 
|---|
| 158 | <pre><code>$ virsh migrate --live --verbose serverX qemu+ssh://vmM.ws.nsrc.org/system</code></pre> | 
|---|
| 159 | <p>where M is your group number. If you try without <code>--live</code> you may see a short pause in the output of the running VM.</p> | 
|---|
| 160 | <h2 id="using-virt-manager-gui"><a href="#using-virt-manager-gui"><span class="header-section-number">5.2</span> Using virt-manager GUI</a></h2> | 
|---|
| 161 | <p>Start the virt-manager GUI. You should see a connection to your own hypervisor: <code>localhost (QEMU)</code></p> | 
|---|
| 162 | <p>Now you are going to add a connection to another hypervisor.</p> | 
|---|
| 163 | <ul> | 
|---|
| 164 | <li><code>File > Add Connection</code></li> | 
|---|
| 165 | <li>Hypervisor: QEMU/KVM</li> | 
|---|
| 166 | <li><code>[X]</code> Connect to remote host | 
|---|
| 167 | <ul> | 
|---|
| 168 | <li>Method: SSH</li> | 
|---|
| 169 | <li>Username: nsrc</li> | 
|---|
| 170 | <li>Hostname: vmN.ws.nsrc.org (where N is the next group)</li> | 
|---|
| 171 | </ul></li> | 
|---|
| 172 | <li>Connect</li> | 
|---|
| 173 | </ul> | 
|---|
| 174 | <p>The first time you connect, you may be questioned about the authenticity of the other host's SSH key. Type "yes" in full, and press OK.</p> | 
|---|
| 175 | <p>You will then be prompted for the ssh password to the other server. Type the same password as you would normally use to login to that machine. (In a real environment you would streamline this using ssh keys).</p> | 
|---|
| 176 | <p>You should now see the other hypervisor listed in the window, together with any VMs running there. To perform the migration:</p> | 
|---|
| 177 | <ul> | 
|---|
| 178 | <li>Double-click on the VM you want to migrate to get a console.</li> | 
|---|
| 179 | <li>Select <code>Virtual Machine > Migrate...</code></li> | 
|---|
| 180 | <li>The drop down "New host" chooses the host you want to migrate to</li> | 
|---|
| 181 | <li>("Migrate offline" means non-live, you can ignore this)</li> | 
|---|
| 182 | <li>Click Migrate</li> | 
|---|
| 183 | </ul> | 
|---|
| 184 | <p>The console will disconnect because the machine is no longer running where it was before.</p> | 
|---|
| 185 | <p>Close the console window, look at the list of VMs and you should see that your VM is now running on the other host, so you can double-click to see it there. If this is a remote host you will need to enter the ssh password again.</p> | 
|---|
| 186 | <p>You should be able to migrate the VM back again in exactly the same way, from the same GUI instance. (In this way, a single machine running virt-manager could control a whole network of VM servers)</p> | 
|---|
| 187 | <h1 id="optional-exercises"><a href="#optional-exercises"><span class="header-section-number">6</span> Optional exercises</a></h1> | 
|---|
| 188 | <p>Find two other groups who are happy to host your VM. Migrate your VM from yours to the first, then from the first to the second, then back to your host.</p> | 
|---|
| 189 | <p>You can do this easily in the virt-manager GUI.</p> | 
|---|
| 190 | <p>Alternatively, it's also straightforward in the virsh command line. You can issue commands to other hosts using the <code>-c</code> flag. For example, this is how you run <code>virsh list</code> on a remote hypervisor:</p> | 
|---|
| 191 | <pre><code>virsh -c qemu+ssh://<hostname>/system list</code></pre> | 
|---|
| 192 | <p>A third-party command to migrate a VM from <code><oldhost></code> to <code><newhost></code> looks like this:</p> | 
|---|
| 193 | <pre><code>virsh -c qemu+ssh://<oldhost>/system migrate --live --verbose \ | 
|---|
| 194 | <vmname> qemu+ssh://<newhost>/system</code></pre> | 
|---|
| 195 | </body> | 
|---|
| 196 | </html> | 
|---|