一、
xen虚拟状态:
 r: 运行
 b: 阻塞
 p: 暂停
 s: 停止
 c: 崩溃
 d: dying, 正在关闭的过程中

 

二、创建xen的pv模式虚拟机

         1、kernel (本身系统内核既可运行dom0中也可运行在domu中)
         2、initrd或initramfs
         3、DomU内核模块
         4、根文件系统
         5、swap设备
         6、DomU的配置文件

 

三、xm的配置文件:
             kernel:内核

 

             ramdisk: initramfs或initrd


             name: 域名称


             memory: 内存大小

 

             disk: 磁盘设备文件列表,格式disk=["disk1", "disk2",], 每个disk都由三个参数进行定义:“backend-dev”,“frontend-dev”,“mode”
                      backend-dev: 有两种类型,物理设备,虚拟磁盘映像文件,格式为分别为phy:device和file:/path/to/p_w_picpath_file; 
                      front-dev: 定义其在DomU中设备类型;虚拟磁盘映像文件对应的设备文件名称通常为xvd[a-z]
                      mode: 访问权限模型,r, w


          vcpus: 虚拟CPU的个数;


          root: 根文件系统所在的设备;


         extra: 传递给内核的额外参数;selinux=0

         on_reboot: 执行xm reboot命令时的操作,有destroy和restart;


         on_crash: 有destroy, restart, preserve(保存崩溃时的信息以用于调试)


         vif :vif = ['ip="172.16.100.11", bridge=br0']
                      type: 设备类型,默认为netfront
                      mac: 指定mac地址;
                      bridge: 指定桥接到的物理设备
                      ip: ip地址;
                      script: 配置此接口的脚本文件
                      vifname: 后端设备名称


         bootloader: 引导器文件的路径,一般指的PyGrub的路径; 

 

四、根文件系统制作步聚

root@logicserver ~]# mkdir /xen/vm1 -pv
mkdir: 已创建目录 "/xen"
mkdir: 已创建目录 "/xen/vm1"
[root@logicserver ~]# cd /xen/vm1
[root@logicserver vm1]# dd if=/dev/zero of=centos6.img bs=1M oflag=direct seek=1023 count=1 
[root@logicserver vm1]# ll -lh
总用量 1.0M
-rw-r--r--. 1 root root 1.0G 9月   8 16:48 centos6.img
[root@logicserver vm1]# du -sh centos6.img 
1.0M centos6.img

 

格式化centos6.img和挂载到/mnt

[root@logicserver vm1]# mke2fs -t ext4 centos6.img 
mke2fs 1.41.12 (17-May-2010)
centos6.img is not a block special device.
无论如何也要继续? (y,n) y
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
65536 inodes, 262144 blocks
13107 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=268435456
8 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks: 
 32768, 98304, 163840, 229376
正在写入inode表: 完成                            
Creating journal (8192 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override. 
[root@logicserver vm1]# mount -o loop centos6.img /mnt
[root@logicserver vm1]# ls /mnt
lost+found
[root@logicserver vm1]# df -lh
文件系统       容量  已用  可用 已用%% 挂载点
/dev/sda2              50G  4.6G   43G  10% /
tmpfs                 462M     0  462M   0% /dev/shm
/dev/sda1             120M   62M   50M  56% /boot
/dev/sda5             400G   41G  339G  11% /data0
/xen/vm1/centos6.img  976M  1.3M  908M   1% /mnt

 

创建系统用到基本目录

[root@logicserver mnt]# mkdir -pv etc/{init,rc.d} bin sbin lib64 dev proc sys tmp var
mkdir: 已创建目录 "etc"
mkdir: 已创建目录 "etc/init"
mkdir: 已创建目录 "etc/rc.d"
mkdir: 已创建目录 "bin"
mkdir: 已创建目录 "sbin"
mkdir: 已创建目录 "lib64"
mkdir: 已创建目录 "dev"
mkdir: 已创建目录 "proc"
mkdir: 已创建目录 "sys"
mkdir: 已创建目录 "tmp"
mkdir: 已创建目录 "var"
[root@logicserver mnt]# ls
bin  dev  etc  lib64  lost+found  proc  sbin  sys  tmp  var

 

执行脚本程序移植

[root@logicserver ~]# vim bincp.sh
#!/bin/bash
#
declare -i DebugLevel=0
Target=/mnt
[ -d $Target ] || mkdir $Target &> /dev/null
read -p "A command: " Command
while [ $Command != 'q' -a $Command != 'Q' ]; do
Command=`which $Command | grep -v "^alias" | grep -o "[^[:space:]]*"`
[ $DebugLevel -eq 1 ] && echo $Command
ComDir=${Command%/*}
[ $DebugLevel -eq 1 ] && echo $ComDir
[ -d ${Target}${ComDir} ] || mkdir -p ${Target}${ComDir}
[ ! -f ${Target}${Command} ] && cp $Command ${Target}${Command} && echo "Copy $Command to $Target finished."
for Lib in `ldd $Command | grep -o "[^[:space:]]*/lib[^[:space:]]*"`; do
  LibDir=${Lib%/*} 
  
  
  
  
  [root@logicserver ~]# sh bincp.sh 
A command: init
Copy /sbin/init to /mnt finished.
Copy /lib64/libnih.so.1 to /mnt finished.
Copy /lib64/libnih-dbus.so.1 to /mnt finished.
Copy /lib64/libdbus-1.so.3 to /mnt finished.
Copy /lib64/libpthread.so.0 to /mnt finished.
Copy /lib64/librt.so.1 to /mnt finished.
Copy /lib64/libgcc_s.so.1 to /mnt finished.
Copy /lib64/libc.so.6 to /mnt finished.
Copy /lib64/ld-linux-x86-64.so.2 to /mnt finished.
A command: bash
Copy /bin/bash to /mnt finished.
Copy /lib64/libtinfo.so.5 to /mnt finished.
Copy /lib64/libdl.so.2 to /mnt finished.
A command: ls
Copy /bin/ls to /mnt finished.
Copy /lib64/libselinux.so.1 to /mnt finished.
Copy /lib64/libcap.so.2 to /mnt finished.
Copy /lib64/libacl.so.1 to /mnt finished.
Copy /lib64/libattr.so.1 to /mnt finished.
A command: cat
Copy /bin/cat to /mnt finished.
A command: vim
Copy /usr/bin/vim to /mnt finished.
Copy /lib64/libm.so.6 to /mnt finished.
Copy /usr/lib64/libgpm.so.2 to /mnt finished.
Copy /usr/lib64/perl5/CORE/libperl.so to /mnt finished.
Copy /lib64/libresolv.so.2 to /mnt finished.
Copy /lib64/libnsl.so.1 to /mnt finished.
Copy /lib64/libcrypt.so.1 to /mnt finished.
Copy /lib64/libutil.so.1 to /mnt finished.
Copy /lib64/libfreebl3.so to /mnt finished.
A command: wget
Copy /usr/bin/wget to /mnt finished.
Copy /usr/lib64/libssl.so.10 to /mnt finished.
Copy /usr/lib64/libcrypto.so.10 to /mnt finished.
Copy /lib64/libgssapi_krb5.so.2 to /mnt finished.
Copy /lib64/libkrb5.so.3 to /mnt finished.
Copy /lib64/libcom_err.so.2 to /mnt finished.
Copy /lib64/libk5crypto.so.3 to /mnt finished.
Copy /lib64/libz.so.1 to /mnt finished.
Copy /lib64/libkrb5support.so.0 to /mnt finished.
Copy /lib64/libkeyutils.so.1 to /mnt finished.

 

给init准备好配置文件并且编辑保存

[root@logicserver ~]# cp /etc/init/rcS.conf /mnt/etc/init/
[root@logicserver ~]# vim /mnt/etc/init/rcS.conf
# rcS - runlevel compatibility
#
# This task runs the old sysv-rc startup scripts.
start on startup
stop on runlevel
task
# Note: there can be no previous runlevel here, if we have one it's bad
# information (we enter rc1 not rcS for maintenance).  Run /etc/rc.d/rc
# without information so that it defaults to previous=N runlevel=S.
exec /etc/rc.d/rc.sysinit
~

 

 创建rc.sysinit脚本并用chroot验证

[root@logicserver ~]# vim /mnt/etc/rc.d/rc.sysinit
#!/bin/bash
#
echo -e "\tWelcom to Xen DomU Linux"
/bin/bash
~      
[root@logicserver ~]# chmod +x /mnt/etc/rc.d/rc.sysinit 
[root@logicserver ~]# chroot /mnt
bash-4.1# ls
bin  dev  etc  lib64  lost+found  proc sbin  sys  tmp usr  var
bash-4.1#

 

同步sync到硬盘,并卸载

[root@logicserver ~]# sync
[root@logicserver ~]# sync
[root@logicserver ~]# sync
[root@logicserver ~]# sync 
[root@logicserver ~]# umount /mnt
[root@logicserver ~]# df -lh

 

五、DomU的配置文件

由于他版号太长,把他们这么复制

 [root@logicserver ~]# cp /boot/vmlinuz-2.6.32-279.el6.x86_64 /tmp/vmlinux
[root@logicserver ~]# cp /boot/initramfs-2.6.32-279.el6.x86_64.img /tmp/initramfs

 

复制/etc/xen下例子配置文件

[root@logicserver ~]# cd /etc/xen/ 
[root@logicserver xen]# cp xmexample1 centos6

 

修改配置文件选项有

kernel = "/tmp/vmlinux"
ramdisk="/tmp/initramfs"

memory = 512

name = "centos6"

vcpus = 2

disk = [ 'file:/xen/vm1/centos6.img,xvda,w' ]

extra = "3 selinux=0"

#vif = [ '' ]    /注释

[root@logicserver xen]# vim centos6
#  -*- mode: python; -*-
#============================================================================
# Python configuration setup for 'xm create'.
# You use a separate script for each domain you want to create, or 
# you can set the parameters for the domain on the xm command line.
#============================================================================
#----------------------------------------------------------------------------
# Kernel p_w_picpath file.
kernel = "/tmp/vmlinux"
ramdisk="/tmp/initramfs"
# Optional ramdisk.
#ramdisk = "/boot/initrd.gz"
# The domain build function. Default is 'linux'.
#builder='linux'
# Initial memory allocation (in megabytes) for the new domain.
#
# WARNING: Creating a domain with insufficient memory may cause out of
#          memory errors. The domain needs enough memory to boot kernel
#          and modules. Allocating less than 32MBs is not recommended.
memory = 512
# A name for your domain. All domains must have different names.
name = "centos6"
# 128-bit UUID for the domain.  The default behavior is to generate a new UUID
# on each call to 'xm create'.
#uuid = "06ed00fe-1162-4fc4-b5d8-11993ee4a8b9"
# List of which CPUS this domain is allowed to use, default Xen picks
#cpus = ""         # leave to Xen to pick
#cpus = "0"        # all vcpus run on CPU0
#cpus = "0-3,5,^1" # all vcpus run on cpus 0,2,3,5
#cpus = ["2", "3"] # VCPU0 runs on CPU2, VCPU1 runs on CPU3
# Number of Virtual CPUS to use, default is 1
#vcpus = 1
vcpus = 2
#----------------------------------------------------------------------------
# Define network interfaces.
# By default, no network interfaces are configured.  You may have one created
# with sensible defaults using an empty vif clause:
#
# vif = [ '' ]
#
# or optionally override backend, bridge, ip, mac, script, type, or vifname:
#
# vif = [ 'mac=00:16:3e:00:00:11, bridge=xenbr0' ]
#
# or more than one interface may be configured:
#
# vif = [ '', 'bridge=xenbr1' ]
vif = [ '' ]
#----------------------------------------------------------------------------
# Define the disk devices you want the domain to have access to, and
# what you want them accessible as.
# Each disk entry is of the form phy:UNAME,DEV,MODE
# where UNAME is the device, DEV is the device name the domain will see,
# and MODE is r for read-only, w for read-write.
#disk = [ 'phy:hda1,hda1,w' ]
disk = [ 'file:/xen/vm1/centos6.img,xvda,w' ]
#----------------------------------------------------------------------------
# Define frame buffer device.
#
# By default, no frame buffer device is configured.
#
# To create one using the SDL backend and sensible defaults:
#
# vfb = [ 'sdl=1' ]
#
# This uses environment variables XAUTHORITY and DISPLAY.  You
# can override that:
#
# vfb = [ 'sdl=1,xauthority=/home/bozo/.Xauthority,display=:1' ]
#
# To create one using the VNC backend and sensible defaults:
#
# vfb = [ 'vnc=1' ]
#
# The backend listens on 127.0.0.1 port 5900+N by default, where N is
# the domain ID.  You can override both address and N:
#
# vfb = [ 'vnc=1,vnclisten=127.0.0.1,vncdisplay=1' ]
#
# Or you can bind the first unused port above 5900:
#
# vfb = [ 'vnc=1,vnclisten=0.0.0.0,vncunused=1' ]
#
# You can override the password:
#
# vfb = [ 'vnc=1,vncpasswd=MYPASSWD' ]
#
# Empty password disables authentication.  Defaults to the vncpasswd
# configured in xend-config.sxp.
#----------------------------------------------------------------------------
# Set the kernel command line for the new domain.
# You only need to define the IP parameters and hostname if the domain's
# IP config doesn't, e.g. in ifcfg-eth0 or via DHCP.
# You can use 'extra' to set the runlevel and custom environment
# variables used by custom rc scripts (e.g. VMID=, usr= ).
# Set if you want dhcp to allocate the IP address.
#dhcp="dhcp"
# Set netmask.
#netmask=
# Set default gateway.
#gateway=
# Set the hostname.
#hostname= "vm%d" % vmid
# Set root device.
root = "/dev/xvda ro"
# Root device for nfs.
#root = "/dev/nfs"
# The nfs server.
#nfs_server = '192.0.2.1'  
# You only need to define the IP parameters and hostname if the domain's
# IP config doesn't, e.g. in ifcfg-eth0 or via DHCP.
# You can use 'extra' to set the runlevel and custom environment
# variables used by custom rc scripts (e.g. VMID=, usr= ).
# Set if you want dhcp to allocate the IP address.
#dhcp="dhcp"
# Set netmask.
#netmask=
# Set default gateway.
#gateway=
# Set the hostname.
#hostname= "vm%d" % vmid
# Set root device.
root = "/dev/xvda ro"
# Root device for nfs.
#root = "/dev/nfs"
# The nfs server.
#nfs_server = '192.0.2.1'  
# Root directory on the nfs server.
#nfs_root   = '/full/path/to/root/directory'
# Sets runlevel 4.
extra = "3 selinux=0"
#----------------------------------------------------------------------------
# Configure the behaviour when a domain exits.  There are three 'reasons'
# for a domain to stop: poweroff, reboot, and crash.  For each of these you
# may specify:
#
#   "destroy",        meaning that the domain is cleaned up as normal;
#   "restart",        meaning that a new domain is started in place of the old
#                     one;
#   "preserve",       meaning that no clean-up is done until the domain is
#                     manually destroyed (using xm destroy, for example); or
#   "rename-restart", meaning that the old domain is not cleaned up, but is
#                     renamed and a new domain started in its place.
#
# In the event a domain stops due to a crash, you have the additional options:
#
#   "coredump-destroy", meaning dump the crashed domain's core and then destroy;
#   "coredump-restart', meaning dump the crashed domain's core and the restart.

六 启动虚拟机