You are going to install Linux from a CD-ROM image. This is the simplest installation method and can be used to install any operating system such as Windows.
The Linux distribution we will use is called "Turnkey Linux" and we have chosen it because it is very quick to install and is available with a choice of ready-to-run applications, in this case we've chosen Wordpress.
NOTE: all the commands in this exercise are run as the root user. If you are logged in as a regular user, use sudo -s to get a root shell.
$ sudo -s
#Before we create and install VMs, we need to change default settings in the cluster (this should have been done before, but we're doing it to be safe).
Do this on the MASTER node:
# gnt-cluster modify -H kvm:kernel_path=,initrd_path=,vnc_bind_address=0.0.0.0This ensures that instances boot directly from their own disk images, not using a kernel on the host, and allows allows VNC consoles to connect across the network.
Ganeti requires an "OS definition" - a collection of scripts which ganeti uses to create, export and import an operating system.
We will install one called ganeti-os-noop. It gets its name from "no operation" - it's a dummy script that does nothing. It's up to you to start the VM with a CD image attached.
First, create a file /etc/apt/sources.list.d/grnet.list containing the following line:
deb http://repo.noc.grnet.gr/ wheezy mainNow add the repository signing key:
# wget -O - http://repo.noc.grnet.gr/grnet.gpg.key | apt-key add -Finally, install the package:
# apt-get update
# apt-get install ganeti-os-noopOnce this has been done on all nodes on the cluster, then on the master node you can run the following command to check it's available:
# gnt-os list
Name
debootstrap+default
noop                    << THIS ONE IS NEWIf not, use gnt-os diagnose to help work out what the problem is.
If using DRBD, the ISO images used for CD installs must be present on all nodes in the cluster, in the same path.
You could copy them to local storage on the master node, and then use gnt-cluster copyfile to distribute them to local storage on the other nodes. However to make things simpler, we've made all the ISO images available on an NFS share (Network File Service), which you can connect to.
On every node, create a empty directory /iso:
# mkdir /isoAnd now mount the file share:
# apt-get install nfs-common
# mount s1.ws.nsrc.org:/iso /isoCheck that you can see the shared files:
# ls /isoInstall a VNC Viewer application on your laptop. (Note that RealVNC does not appear to work with KVM)
Note: each pair of people working together can create their own instance. However you will all have to log into the MASTER node of your cluster to perform these commands.
For example, if you working on host3 then you will have to login to host1 (your cluster's master node). You will then create a VM called
wordpress3and instruct ganeti to create it on your host using the flag-n host3.ws.nsrc.org
Run the following command to create an instance. Note that we don't start it yet, because we want to temporarily attach the CD-ROM image at start time.
# gnt-instance add -t plain -o noop \
    -s 2G -B minmem=256M,maxmem=512M \
    -n hostN.ws.nsrc.org \
    --no-start --no-name-check --no-ip-check \
    wordpressX... replacing N with your group's master node and X with your own host number.
Explanation:
-t plain means simple LVM (not replicated with DRBD)-o noop means to use the "noop" OS definition-s 4G means to create a 4GB disk drive-B minmem=256M,maxmem=512M sets the memory limits for this VM. It will try to run it with 512MB, but if not enough memory is available it may shrink it down to 256MB.-n hostN.ws.nsrc.org says which node to create this VM on. If you omit this then the cluster balancer will pick the least-loaded node.--no-start means don't start the VM after creating it--no-name-check means don't check that wordpressX exists in the DNS (because it doesn't!)--no-ip-check means if you found the name in the DNS, don't check that the IP address is not in useYou will see some messages about creating the instance being created.
Now use gnt-instance list to see that the instance was created properly:
# gnt-instance list -o +network_port
Instance    Hypervisor OS   Primary_node      Status     Memory Network_port
wordpressX  kvm        noop hostN.ws.nsrc.org ADMIN_down      - 11XXXMake a note of the Network_port - you'll need this to connect to the VNC console shortly.
Start the VM using the following command, which attaches the CD-ROM image temporarily and boots from it:
# gnt-instance start \
    -H boot_order=cdrom,cdrom_image_path=/iso/turnkey-wordpress-13.0-wheezy-amd64.iso \
    wordpressX
Waiting for job 125 for wordpressX ...Check that your VM status has changed from "ADMIN_down" to "running":
# gnt-instance list -o +network_portOn your laptop, open a VNC viewer application and point it at <Primary_node>:<Network_port>. If you have previously set a console password you'll be prompted for it.
NOTE: if you get a "kernel panic" then for the purposes of this workshop it may be necessary to update the version of qemu-kvm in your host:
apt-get install -t wheezy-backports qemu-kvmShut down your guest:
gnt-instance shutdown --timeout=0 wordpressXThen start it again using the long line shown above with boot_order=cdrom.
If you see the Turnkey splash screen then hit Enter to start installation (it will do this automatically after 30 seconds anyway).
With Turnkey Linux, only a few questions now have to be answered to complete the installation. Use Tab to move between fields.
At this point you should get a configuration screen saying "WORDPRESS appliance services" giving URLs with the IP address which your machine has picked up via DHCP.
Point your laptop's web browser at the first URL to login. You will see additional URLs for web shell, Webmin and PHPMyAdmin - you can try those too.
Your installation is complete. As long as you remember your VM's IP address you can disconnect the VNC console now.
Turnkey has a simple set of options from the console for configuring IP address, rebooting and shutting down. If you go into "Advanced Menu" and then "Quit" you will get a regular Linux console login. Login as root and then type "confconsole" if you want to get back into the configuration screen.
Your VM should have an openssh server already installed.
Hence from your laptop you should now be able to log in to your VM on the IP address shown previously.
To shut down the instance from the Ganeti master node, you can issue the following command:
# gnt-instance shutdown wordpressXThis will send ACPI shutdown request (similar to pressing the power button on a modern PC) and wait up to 2 minutes for the shutdown sequence to complete.