===== I have moved on! =====

Please join me at Virtually Lost in the search to find Nirvana using virtualization technologies.

Monday, May 7, 2007

Installing the 3.2 XenEnterprise Admin Console on OSX

So, Enterprise 3.2 came out at the beginning of the month, and it mentions that a new way of using fonts is included in the console, so I have to upgrade if I actually want to see the text console for my Linux VMs. The thing is that some additional tweaking is necessary. Here are my upgraded instructions, but these only apply to version 3.2 of the console:


Here are the steps to get your XenEnterprise Administrative Console running on OSX 10.4.9:


  • You need to install Java version 6, so get your Apple Developper Account (here to get one), and navigate their site:

    developer.apple.com -> Login -> Downloads -> Java -> Java SE 6.0 Release 1 DP6 (Disk Image)


    The file you need to get is called javase6release1dp6.dmg
    The release notes are here

  • Install Java SE 6.0 on your OSX

  • From the XenEnterprise Linux Clients CD, transfer the files /client-install/xenserver-client-3.2.0-2004.noarch.rpm and xenserver-client-jars-3.2.0-2004.noarch.rpm to a Linux box.

  • On the Linux box, run rpm2targz on both those files, this will create .tar.gz archives of these .rpm files.

  • Transfer those two .tar.gz files to your Mac

  • On the Mac:

    cd /

    sudo tar -xzvf ~user/xenserver-client-3.2.0-2004.noarch.tar.gz

    sudo tar -xzvf ~user/xenserver-client-jars-3.2.0-2004.noarch.tar.gz

    cd /opt/xensource/xenserver-client/bin


  • Edit the file xenserver-client.sh and change:

    ${BASEDIR}/jre/bin/java \

    to

    /System/Library/Frameworks/JavaVM.framework/Versions/1.6/Commands/java \
    -XX:+UseTLAB \


  • Start the ./xenserver-client.sh script.


Tuesday, February 13, 2007

Installing the XenEnterprise Admin Console on OSX


Here are the steps to get your XenEnterprise Administrative Console running on OSX 10.4.8:


  • From the XenEnterprise CD, transfer the files /client-install/xenserver-client-3.1.0-1332.i386.rpm and xenserver-client-jars-3.1.0-1332.i386.rpm to a Linux box.

  • On the Linux box, run rpm2targz on both those files, this will create .tar.gz archives of these .rpm files.

  • Transfer those two .tar.gz files to your Mac

  • On the Mac:

  • cd /
    sudo tar -xzvf ~user/xenserver-client-3.1.0-1332.i386.tar.gz
    sudo tar -xzvf ~user/xenserver-client-jars-3.1.0-1332.i386.tar.gz
    cd /opt/xensource/xenserver-client/bin

  • Edit the file xenserver-client.sh and change:

  • ${BASEDIR}/jre/bin/java \


    to


    /usr/bin/java

  • Start the ./xenserver-client.sh script.


The linux text console is not functional as it shows yellow blocks instead of actual letters. My guess is that it is referring to an non-existant font on OSX.

Sunday, February 11, 2007

Migrating VMs from Xen to XenEnterprise


As a reseller, it's only normal to run the product you are reselling. The problem is that we've been running our production servers on Xen3 for the last few years and XenSource do no include a migration from Open Source Xen to their commercial offering.


So I have to make up my own.


First, some reverse engineering: XenEnterprise provides a VM export and import function. The "format" of an export is:

<VM export name>/ova.xml   (config file)
<VM export name>/<disk>/chunk-00000000<n>.gz (disk chunks)


One of the problems you face is that each chunk is a maximum raw size of 1000000000 bytes, and then is run through gzip. Here's how you can generate your own chunks from your current block device. All of this article's commands are being done on my ORIGINATING Xen server, not the destination XenEnterprise server.

cd /tmp
mkdir myvm
cd myvm
mkdir hda3
cd hda3
dd if=/dev/gnbd/FC4 of=chunk-000000000 count=1000000 bs=1000
gzip chunk-000000000
dd if=/dev/gnbd/FC4 of=chunk-000000001 count=1000000 skip=1000000 bs=1000
gzip chunk-000000001
dd if=/dev/gnbd/FC4 of=chunk-000000002 count=1000000 skip=2000000 bs=1000
gzip chunk-000000002


and so on until you have copied your whole block device. Keep note of the raw length of that last chunk, since we will need to tell the config file the raw length of the block device we want at the other end. Another way to know the length of the block device is to do:

dd if=/dev/gnbd/FC4 of=/dev/null


and the very last line will say something like:

2306867200 bytes (2.3 GB) copied, 211.411 seconds, 10.9 MB/s


So, in my case, the block device was 2306867200 bytes in length.


Do this for each of your original VM's disks. Here's is what your directory tree will end up looking like:

# cd ..
# find ./myvm -print
./myvm
./myvm/hda3
./myvm/hda3/chunk-000000002.gz
./myvm/hda3/chunk-000000000.gz
./myvm/hda3/chunk-000000001.gz
./myvm/hda2
./myvm/hda2/chunk-000000000.gz


Now on to the config file. It is a simple XML file and just gives the receiving XenEnterprise an idea of the originating VMs disk layouts. Your config file will be called /tmp/myvm/ova.xml Here's mine:


<?xml version="1.0" ?>
<appliance version="0.1">
<vm name="vm">
<label>
MyVM
</label>
<shortdesc>
Fedora Core 4 test machine
</shortdesc>
<config mem_set="262144000" vcpus="1"/>
<hacks is_hvm="false" kernel_boot_cmdline="root=/dev/hda3 ro ">
<!--This section is temporary and will be ignored in future. Attribute is_hvm ("true" or "false") indicates whether the VM will be booted in HVM mode. In future this will be autodetected. Attribute kernel_boot_cmdline contains the kernel commandline for the case where a proper grub menu.lst is not present. In future booting shall only use pygrub.-->
</hacks>
<vbd device="hda2" function="swap" mode="w" vdi="vdi_hda2"/>
<vbd device="hda3" function="root" mode="w" vdi="vdi_hda3"/>
</vm>
<vdi name="vdi_hda2" size="134217728" source="file://hda2" type="dir-gzipped-chunks" variety="system"/>
<vdi name="vdi_hda3" size="2306867200" source="file://hda3" type="dir-gzipped-chunks" variety="system"/>
</appliance>


The mem_set is 256 megs, the function= can be anything, and I have no idea what the variety= means... Notice that source= doesn't actually match my real path. That's normal. The more observant of you will notice that I am actually migrating a swapfile as part of this import. Waste of time? Only you can say :-)


Now it is time for the actual import. To do this properly, you will need a statically linked file from the XenEnterprise server itself:

scp myxenterpriseserver:/opt/xensource/bin/xe /tmp/

You are now ready for the actual import. Nothing simpler:

/tmp/xe vm-import -u root -pw myrootpassword \
-h myxenenterpriseserver dir-name=/tmp/myvm/


The following lines tells you everything is honky-dory:

New VM uuid: 8453f105-bedd-4dbc-98fb-42b8b6605b44
Processing step 4/4 -
Import successful


You are now in good shape. Start your XenEnterprise Admin console and try to start up the new VM. If it bombs at kernel bootup, it is because the XenEnterprise guest initrd is incompatible with your VM. Don't despair, that's the subject of my next article...

Monday, January 15, 2007

Problems with booting Xen guests after going to version 3

If you are experiencing bootup problems with your Xen v3 guests, it may very be that you have not completely prepared your guests with the Xen v3 modules.

You see, with Xen v2, most people compiled their own kernels, both for the xen0/dom0 and xenU/domU. Most admins compiled in the ext3 support or necessary filesystem drivers directly into the XenU kernel, and were able to boot the Virtual Machines with no hiccups.
With Xen v3, the kernel is the same with both dom0 and domU, and everything is modular. Most admins even have to make sure to include a initrd to even boot their dom0. How do you do the same with the domU ??

Follow these two steps:


  1. Add the following in your xmconfig file for that domU:
    ramdisk="/boot/initrd-2.6.18-1.2869.fc6xen.img"

  2. Tar up the Xen modules, mount your domU image on a loopback and copy the modules to the domU image.
    cd /lib/modules
    tar -czvf ./2.6.18-1.2869.fc6xen-modules.tgz ./2.6.18-1.2869.fc6xen/
    mkdir /mnt/guest-os
    mount -o loop /someclient_image /mnt/guest-os
    cd /mnt/guest-os
    tar -xzvf /lib/modules/2.6.18-1.2869.fc6xen.tgz
    cd /
    umount /mnt/guest-os


That should be all, you should now be able to start your domU.
Note: This article takes for granted that your actual kernel name is vmlinux-2.6.18-1.2869.fc6xen :-) YMMV

Monday, January 1, 2007

Compiling XNU (OSX Kernel)

We are looking into getting OCF into the OSX kernel. That means we have to first be able to compile the XNU/Darwin kernel. I followed this howto.

Note a few points:


  • Make sure to install GCC 3.3 on a OSX machine.

  • Get the building utilities pre-built here.

  • Get the Xnu kernel tarball, either PPC or Intel.


So, all of this is rather straightforward, BUT I had install both GCC 4.0 and GCC3.3, and I think that XNU is allergic to GCC4.0

I ended up relinking all the /usr/bin/gcc, /usr/bin/c++, and such to their gcc 3.3 equivalent. Once done, the compile went rather well, until the very end and then ended up complaining about -lcc_kext not found. The trick is to modify makedefs/MakeInc.def and to change:

#
# Default runtime libraries to be linked with the kernel
#
export LD_KERNEL_LIBS = -lcc_kext

with

#
# Default runtime libraries to be linked with the kernel
#
export LD_KERNEL_LIBS = -L/usr/lib/gcc/darwin/3.3/ -lcc_kext


That's it.

Here are a few links that might interest you for understanding of building of the XNU kernel:
MacOSX Forge
OpenDarwin
O'Reilly
Building Intel xnu with darwinbuild