Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP

Kexec loader

Greg DeKoenigsberg edited this page · 10 revisions
Clone this wiki locally

Create a single kernel to boot all Linux based EMIs

https://code.launchpad.net/~smoser/+junk/kexec-loader

Normally on Eucalyptus, when you want to run a new image you need three components ( kernel / ramdisk / disk image ). Each components need to be bundled / uploaded / registered. They gave you respectively an eki / eri / emi. You then register your emi with the correct eki / eri. This process is time consuming and can be error prone.

The following kernel / ramdisk is able to boot any images which has got a grub1 or grub2 correctly configured in either grub.conf / menu.lst / grub.cfg. It initially boots the image with this kernel and then reads grub configuration file to discover kernel configured within the image and kexec into this kernel.

How to use it.

Download it

For now, you can download directly from Github (permanent location soon):

wget -O vmlinuz https://github.com/monolive/euca-single-kernel/blob/master/examples/vmlinuz?raw=true
wget -O initrd-kexec https://github.com/monolive/euca-single-kernel/blob/master/examples/initrd-kexec_load?raw=true

Register kernel / ramdisk

Before being available, you will need to register them on your eucalyptus cloud.

euca-bundle-image --kernel true -i <kernel filename>
euca-upload-bundle -m <manifest> -b <bucket>
euca-register <bucket>/<manifest>
euca-bundle-image --ramdisk true -i <ramdisk filename>
euca-upload-bundle -m <manifest> -b <bucket>
euca-register <bucket>/<manifest>

Set these as your default kernel and ramdisk:

You aren't required to do the step of setting the eki / eri as the default, but if you don't, you still have to associate every emi you register with this eki/eri pair, and who wants to do that?

euca-modify-property -p cloud.images.defaultkernelid=<eki>
euca-modify-property -p cloud.images.defaultramdiskid=<eri>

Find images that work with it

There's plenty of prepackaged cloud images available from various places. We've got a list of Kexec images that we've done some rudimentary testing on.

Enjoy

Yes, now profit by not having to specify kernel and ramdisk for every image you register. If you use an image created by one of the popular image creation tools, which puts a kernel, a useful ramdisk & a grub config inside the filesystem, they should Just Work.

How to create your own kexec ramdisk

Requirements

  1. Ubuntu instance (can be an EMI running on eucalyptus)
  2. Check out kexec-loader from launchpad
bzr branch lp:~smoser/+junk/kexec-loader

How to

  1. Copy all files from conf directory to /etc/initramfs-tools/
cp -ax kexec-loader/conf/* /etc/initramfs-tools
  1. Update initramfs
update-initramfs -c -k `uname -r`
  1. Bundle / upload / register - kernel / initramdisk pair

NB: Make sure to have kexec installed (kexec-tools)


category.images

Something went wrong with that request. Please try again.