编译服务/KIWI/QEMU-VMDK镜像

Jump to: navigation, search

Susemini.png 本文处于需要翻译的文章的状态,欢迎您积极参与翻译与修订。 翻译人员:无,修订人员:无。

Kiwi for Qemu and Vmdk images

Introduction

The base of this document is that the first writer needed to build Qemu files for use with Xen (Full virtualisation) so I decided to use kiwi to create them. Just a reminder KIWI is a project that changes very fast. In the coming time this document shall be extended and updated. The working environment in this document is a suggestion, like directories for the storage of images can be changed according to the users wish.

Used system

Every opensuse 10.2 or sles 10.0 will do, But I used Opensuse 10.2 x86_64 with Xen installed so I could test the resulting qemu files and boot them.

Preferred situation

Make sure that you have enough diskspace for:

1) Repository of the installation source (4.3 GB if you make a copy of the DVD version) more if you have more repositories and architectures.

2) Enough diskspace for the build of the image (who is as big as you want it. Remember its a harddisk image..)

3) Enough diskspace for the build of the qemu and vmdk images, Kiwi makes standard both + a raw image + the initrd files. So you need at least 3 times the build harddisk space.

Step 1 Getting Kiwi

The KIWI main repository is

http://ftp.opensuse.org/pub/opensuse/repositories/openSUSE:/Tools

Don't forget to take the right configuration for your system. In my case,

http://ftp.opensuse.org/pub/opensuse/repositories/openSUSE:/Tools/openSUSE_10.2/

And add the resource to yast, yum or smart

Step 2 Install the Kiwi tools.

The full set of kiwi tools consists out of:

                                                       -   

kiwi                   - The primary program installed in /usr/sbin/kiwi
                       - All modules and extra files are installed in /usr/share/kiwi
kiwi-desc-isoboot      - Configuration files for iso-bootimages (LiveDVD/CD) installed in /usr/share/kiwi/images
kiwi-desc-netboot      - Configuration files for net-bootimages (Netboot) installed in /usr/share/kiwi/images
kiwi-desc-usbboot      - Configuration files for usb-bootimages (USBstick) installed in /usr/share/kiwi/images
kiwi-desc-vmxboot      - Configuration files for vmx-bootimages (Qemu clients and VMDK clients (vmware)) installed in /usr/share/kiwi/images
kiwi-desc-xenboot      - Configuration files for xen-bootimages (Xen Clients) installed in /usr/share/kiwi/images
kiwi-desc-xennetboot   - Configuration files for xennetboot-bootimages (Xenimages booting from network) installed in /usr/share/kiwi/images
kiwi-pxeboot           - Configuration files for pxe-bootimages (pxe bootimages) installed in /usr/share/kiwi/images


osc                    - OpenSUSE build service command-line tool

perl-Socket-MsgHdr     - Perl library used by kiwi
richclient             - The base for the future graphical client  
richclient-debuginfo   - Debug info graphical client


Step 3 Creating the Kiwi image environment.

To grow your kiwi images you need to create a spacefull situation and some ingredients.

The repositories.

You need at least one repository, these can be local or remote over nfs, ftp. It is going to connected by the smart packager so you can place it everywhere, or just use the installation repositories on the internet.

I use local repositories, because they are fast.

To create repository you just create a directory with a meaningful name and copy the contents of the DVD to this place.

Example's

/vm/repository/oss10.2
/vm/repository/oss10.2-64
/vm/repository/sles10
/vm/repository/sles10-64

The kiwi image directories.

Do the same for your kiwi image directories

/vm/kiwi-build    - the directory where later the builds are created
/vm/kiwi-image    - the directory where later the final images are created

The image configuration directory.

Image configurations are in directory /usr/share/kiwi/images

There is a BETA example of the kiwi-desc-qemu-vmdk package is available in:

http://software.opensuse.org/download/home:/gwayne/openSUSE_10.2/noarch/

To have a basic configuration its easy to make a copy of the image configuration directory it provides.

cp -a qemu-vmdk-suse-10.2

This directory contains

root          - This directory contains all the files that shall be copied to the final image
                For example you can create directory etc and place your ntp.conf in it. Or your passwd/shadow files                 

repo          - A extra repository directory where extra rpm files are placed used in the installation

config.sh     - Configuration file that contains the actions executed inside the chroot environment of the image.
config.xml    - Configuration file of the image parameters.

build.sh      - My buildscript for lazy people, actually just the commands to build the full image.


First modifications so that the system actually works.

There have to be modifications in two directories

Your own new image directory

/usr/share/kiwi/image/qemu-vmdk-suse-10.2-myownversion

And the boot image directory you are going to use

/usr/share/kiwi/image/vmxboot/suse-10.2

In both you have to change the source directories you use in the config.xml file.

The one in vmxboot

        <repository type="yast2" status="replaceable">
                <!--<source path="opensuse://10.2"/>-->
        <source path="/image/dist/full-10.2-i386"/>            <---------- change this one to your resources


And the one in qemu-vmdk-suse-10.2-myownversion extended to use two repositories, I added in this example the repo directory so you can add personal packages. You can also put a third one, with all updates. Just make sure that the updates are only the ones of the right architecture.

       
       <repository type="rpm-dir">
        <source path="this://repo"/>
       </repository>

       <repository type="yast2">
                <!--<source path="/image/CDs/full-i386"/>-->
                <!--<source path="/mounts/machcd2/consistent/full-i386"/>-->
                <!--<source path="opensuse://SL-OSS-factory"/>-->
                <source path="/vm/res/oss102"/>                   <---------------- change this one to your own resources
        </repository>

Optional you can change the build.sh script to reflect the environment and be lazy in building.

configdir=/usr/share/kiwi/image/qemu-vmdk-suse-10.2-myownversion <---- change it to your config dir
buildroot=/vm/kiwi-builds/oss102                                 <---- change it to where you want the build to be created
imageroot=/vm/kiwi-images                                        <---- change it to where you want the images to be created 
buildarch=i386                                  <---- because I build on a x86_64 system I have to tell him I want a i386 or x86_64 image                           

# Remove buildroot before starting

cleanup=yes                                      <---- otherwise I get the error "already exists" when I rerun the image build.

So now you should be able to build a 2700 MB test image.

So you either start it with ./build.sh

or on a i386 machine, just replace the variables with your real directories. And start the commands by hand.

kiwi -r $buildroot -p $configdir
kiwi -c $buildroot -d $imageroot

Now you should have a basic image, if you run it with vmware, xen or qemu it should install the bootloader on the first run and then you have a running image.

The root password is linux.

Step 4 Creating your own specific Images.

The config.xml file