黑帽联盟

 找回密码
 会员注册
查看: 1730|回复: 0
打印 上一主题 下一主题

[集群服务] Xen虚拟化技术

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    一、Xen简介
    1、Xen简介

    Xen 英国剑桥大学研发,开源的VMM,是一种类型 1 虚拟机管理程序,它创建系统资源的逻辑池,使许多虚拟机可共享相同的物理资源。

    Xen 是一个直接在系统硬件上运行的虚拟机管理程序。Xen 在系统硬件与虚拟机之间插入一个虚拟化层,将系统硬件转换为一个逻辑计算资源池,Xen 可将其中的资源动态地分配给任何操作系统或应用程序。在虚拟机中运行的操作系统能够与虚拟资源交互,就好象它们是物理资源一样。

    wKioL1eHOtCQ0dM6AAKzRZeK7ag731.png
            Xen 架构

    Xen 运行 3 个虚拟机。每个虚拟机与其他虚拟机都独自运行一个来宾操作系统和应用程序,同时共享相同的物理资源。


    2、Xen的组件

    1)Xen Hypervisor
             分配cpu、内存、interrupt(中断)
    2)Dom0
              特权域,I/O分配:
                                 网络设备:net-front(guestOS),net-backend
                                 块设备:block-front(guestOS),block-backend
              linux kernel:2.6.37支持Dom0 原始支持
                                    3.0对关键特性进行了优化
               提供管理DomU工具栈,用于实现对虚拟机进行添加,启动,快照,停止,删除等操作
    3)Domu
              非特权域,无权直接访问硬件资源
              根据其虚拟化方式实现的方式,有多种类型
                     PV:半虚拟化
                 HVM:完全虚拟化
       PV on HVM:I/O半虚拟化但cpu完全虚拟化
    Xen的PV技术:不依赖于CPU的HVM特性,但要求GuestOS的内核作出修改以知晓自己运行于PV环境,
                             运行于DomU中的OS:linux(2.6.24+),NetBSD,FreeBSD,OpenSolaris
    Xen的HVM技术:依赖于Intel VT或AMD AMD-V,还要依赖于Qemu来模拟IO设备
                                运行于DomU中的OS:几乎所有支持此X86平台的OS
    PV on HVM:CPU为HVM模式运行,IO设备为PV模式运行
                        运行于DomU中的OS:只要OS能驱动PV接口类型的IO设备:net-front,block-front
    wKiom1eHOs6zXdi7AAIpQajYIT0497.png

    wKiom1eHYbvyaC9CAACgAljKMTI310.png


    3、CentOS对Xen的支持

    RHEL 5.7-:默认的虚拟化技术为xen

            kernel version:2.6.18   不能运行在Dom0上,要运行Dom0上需要安装补丁,RHEL提供了安装补丁后的内核 kernel-xen:
           5.8:同时支持Xen和kvm
           6+:仅支持kvm
                   Dom0:不支持
                   DomU:支持
    那如何在CentOS6上使用Xen?
    1)编译3.0以上版本的内核,启动对Dom0的支持
    2)编译Xen程序
    制作好相关程序包的项目:
    xen made easy
    xen4centos:xen官方提供,每个centos镜像站中已经提供了,
    我们可以自定义一个yum源
    1. [root@BAIYU_175 ~]# cd /etc/yum.repos.d/
    2. [root@BAIYU_175 yum.repos.d]# ls
    3. bak  Centos-6.repo  epel-6.repo  Xen-6.repo  Xen-6.repo.orig
    4. [root@BAIYU_175 yum.repos.d]# vi Xen-6.repo
    5. [root@BAIYU_175 yum.repos.d]# cat Xen-6.repo
    6. # CentOS-Base.repo
    7. #
    8. # The mirror system uses the connecting IP address of the client and the
    9. # update status of each mirror to pick mirrors that are updated to and
    10. # geographically close to the client.  You should use this for CentOS updates
    11. # unless you are manually picking other mirrors.
    12. #
    13. # If the mirrorlist= does not work for you, as a fall back you can try the
    14. # remarked out baseurl= line instead.
    15. #
    16. #
    17.   
    18. [Xenbase]
    19. name=CentOS-$releasever - Base - mirrors.aliyun.com
    20. failovermethod=priority
    21. baseurl=http://mirrors.aliyun.com/centos/6/virt/x86_64/xen-46
    22. #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os
    23. #gpgcheck=1
    24. #gpgkey=
    复制代码
    1. 依赖关系解决

    2. ================================================================================================================
    3. 软件包                              架构              版本                            仓库                大小
    4. ================================================================================================================
    5. 正在安装:
    6. xen                                 x86_64            4.6.1-11.el6                    Xenbase            111 k
    7. 为依赖而安装:
    8. SDL                                 x86_64            1.2.14-7.el6_7.1                base               193 k
    9. glusterfs                           x86_64            3.7.5-19.el6                    base               392 k
    10. glusterfs-api                       x86_64            3.7.5-19.el6                    base                56 k
    11. glusterfs-client-xlators            x86_64            3.7.5-19.el6                    base               942 k
    12. glusterfs-libs                      x86_64            3.7.5-19.el6                    base               303 k
    13. kernel                              x86_64            3.18.34-20.el6                  Xenbase             37 M
    14. libxslt                             x86_64            1.1.26-2.el6_3.1                base               452 k
    15. mesa-dri-drivers                    x86_64            11.0.7-4.el6                    base               4.1 M
    16. mesa-dri-filesystem                 x86_64            11.0.7-4.el6                    base                17 k
    17. mesa-dri1-drivers                   x86_64            7.11-8.el6                      base               3.8 M
    18. mesa-libGL                          x86_64            11.0.7-4.el6                    base               142 k
    19. mesa-private-llvm                   x86_64            3.6.2-1.el6                     base               6.5 M
    20. python-lxml                         x86_64            2.2.3-1.1.el6                   base               2.0 M
    21. qemu-img                            x86_64            2:0.12.1.2-2.491.el6            base               836 k
    22. usbredir                            x86_64            0.5.1-3.el6                     base                41 k
    23. xen-hypervisor                      x86_64            4.6.1-11.el6                    Xenbase            927 k
    24. xen-libs                            x86_64            4.6.1-11.el6                    Xenbase            532 k
    25. xen-licenses                        x86_64            4.6.1-11.el6                    Xenbase             85 k
    26. xen-runtime                         x86_64            4.6.1-11.el6                    Xenbase             16 M
    27. yajl                                x86_64            1.0.7-3.el6                     base                27 k
    28. 为依赖而更新:
    29. kernel-firmware                     noarch            3.18.34-20.el6                  Xenbase            6.4 M
    30. libdrm                              x86_64            2.4.65-2.el6                    base               136 k

    31. 事务概要
    32. ================================================================================================================
    33. Install      21 Package(s)
    34. Upgrade       2 Package(s)
    复制代码
    然后修改/etc/grub.conf配置文件
    1. [root@BAIYU_175 ~]# cat /etc/grub.conf
    2. # grub.conf generated by anaconda
    3. #
    4. # Note that you do not have to rerun grub after making changes to this file
    5. # NOTICE:  You have a /boot partition.  This means that
    6. #          all kernel and initrd paths are relative to /boot/, eg.
    7. #          root (hd0,0)
    8. #          kernel /vmlinuz-version ro root=/dev/sda2
    9. #          initrd /initrd-[generic-]version.img
    10. #boot=/dev/sda
    11. default=0
    12. timeout=5
    13. splashimage=(hd0,0)/grub/splash.xpm.gz
    14. hiddenmenu
    15. title  (3.18.34-20.el6.x86_64)
    16.     root (hd0,0)
    17.         kernel /xen.gz dom0_mem=1024M cpufreq=xen dom0_max_vcpus=2 dom0_vcpus_pin
    18.     module /vmlinuz-3.18.34-20.el6.x86_64 ro root=UUID=d393efa7-a8b5-4758-bbf5-2eaead07f8c3 rd_NO_LUKS  KEYBOARDTYPE=pc KEYTABLE=us LANG=zh_CN.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 rd_NO_LVM crashkernel=auto rhgb quiet rd_NO_DM rhgb quiet
    19.     module /initramfs-3.18.34-20.el6.x86_64.img
    20. title CentOS 6 (2.6.32-573.el6.x86_64)
    21.     root (hd0,0)
    22.     kernel /vmlinuz-2.6.32-573.el6.x86_64 ro root=UUID=d393efa7-a8b5-4758-bbf5-2eaead07f8c3 rd_NO_LUKS  KEYBOARDTYPE=pc KEYTABLE=us LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 rd_NO_LVM crashkernel=auto rhgb quiet rd_NO_DM rhgb quiet
    23.     initrd /initramfs-2.6.32-573.el6.x86_64.img
    24. [root@BAIYU_175 ~]#
    复制代码
    然后重启
    1. [root@BAIYU_175 ~]# uname -r
    2. 3.18.34-20.el6.x86_64
    3. [root@BAIYU_175 ~]# xl list     #查看运行的虚拟机,注意此时我们操作的是Dom0,虚拟化平台已经安装完毕,可以创建虚拟机了,
    4. Name                                        ID   Mem VCPUs  State   Time(s)
    5. Domain-0                                     0  1024     2     r-----      36.7
    复制代码
    4、Xen的管理工具栈
    xm/xend:在Xen Hypervisor的Dom0中要启动xend服务,重量级
                      xm:命令行管理工具,有诸多子命令:
                               create,destroy,stop,pause...
    xl:libxenlight提供的Xen的轻量化工具,Xen 4.2 xm和xl同时提供,4.3 xm提示被废弃,
    xe/xapi:提供了对Xen管理的api,因此多用于cloud环境: Xen Server, XCP
    virsh/libvrit: python语言研发   
                       在每一个hyper上安装libvrit库,并启动libvritd服务,就可以用virsh管理它们

    5、XenSrore
          为各Domain提供的共享信息存储空间:有着层级结构的名称空间:位于Dom0

    二、Xen的使用
    1、xl命令详解
    1. [root@BAIYU_175 ~]# xl
    2. Usage xl [-vfN]  [args]

    3. xl full list of subcommands:      #子命令完整列表

    4. create              Create a domain from config file
    5. config-update       Update a running domain's saved configuration, used when rebuilding the domain after reboot.
    6. WARNING: xl now has better capability to manage domain configuration, avoid using this command when possible
    7. list                List information about all/some domains    #列出所有或某个Dom的信息
    8. destroy            Terminate a domain immediately  #之间关掉虚拟机的电源
    9. shutdown            Issue a shutdown signal to a domain #正常关机
    10. reboot              Issue a reboot signal to a domain #正常重启
    11. pci-attach         Insert a new pass-through pci device #增加一个pci设备,热插拔
    12. pci-detach       Remove a domain's pass-through pci device #拆除一个pci设备,热插拔
    13. pci-list            List pass-through pci devices for a domain #查看虚拟机pci设备,除了网卡,查看网卡有专门的命令
    14. pci-assignable-add  Make a device assignable for pci-passthru
    15. pci-assignable-remove
    16.                      Remove a device from being assignable
    17. pci-assignable-list List all the assignable pci devices
    18. pause            Pause execution of a domain #暂停虚拟机,保存在内存中
    19. unpause             Unpause a paused domain  #解除暂停
    20. console             Attach to domain's console #连接虚拟机的控制台
    21. vncviewer           Attach to domain's VNC server.
    22. save                Save a domain state to restore later
    23. #将DomU的内存中的数据转至指定的磁盘文件中,相当于挂起
    24. migrate             Migrate a domain to another host#将虚拟机迁移到另一台物理机上
    25. restore             Restore a domain from a saved state
    26. #从指定磁盘文件中恢复DomU的内存数据,
    27. migrate-receive     Restore a domain from a saved state
    28. dump-core           Core dump a domain  #转存内核?
    29. cd-insert           Insert a cdrom into a guest's cd drive #插入光盘
    30. cd-eject            Eject a cdrom from a guest's cd drive #弹出光盘
    31. mem-max             Set the maximum amount reservation for a domain
    32. #内存最大上限
    33. mem-set             Set the current memory usage for a domain
    34. #内存大小
    35. button-press        Indicate an ACPI button press to the domain
    36. vcpu-list           List the VCPUs for all/some domains #显示虚拟cpu
    37. vcpu-pin            Set which CPUs a VCPU can use
    38. vcpu-set            Set the number of active VCPUs allowed for the domain
    39. vm-list             List guest domains, excluding dom0, stubdoms, etc.
    40. info                Get information about Xen host
    41. sharing             Get information about page sharing
    42. sched-credit        Get/set credit scheduler parameters
    43. sched-credit2       Get/set credit2 scheduler parameters
    44. sched-rtds          Get/set rtds scheduler parameters
    45. domid               Convert a domain name to domain id
    46. domname             Convert a domain id to domain name
    47. rename              Rename a domain #重命名
    48. trigger             Send a trigger to a domain
    49. sysrq               Send a sysrq to a domain
    50. debug-keys          Send debug keys to Xen
    51. dmesg               Read and/or clear dmesg buffer #虚拟机启动时的引导信息
    52. top                 Monitor a host and the domains in real time
    53. network-attach      Create a new virtual network device
    54. network-list        List virtual network interfaces for a domain
    55. network-detach      Destroy a domain's virtual network device
    56. channel-list        List virtual channel devices for a domain
    57. block-attach        Create a new virtual block device #增加一块硬盘
    58. block-list          List virtual block devices for a domain#查看硬盘
    59. block-detach        Destroy a domain's virtual block device #删除一块硬盘
    60. vtpm-attach         Create a new virtual TPM device
    61. vtpm-list           List virtual TPM devices for a domain
    62. vtpm-detach         Destroy a domain's virtual TPM device
    63. uptime              Print uptime for all/some domains
    64. claims              List outstanding claim information about all domains
    65. tmem-list           List tmem pools
    66. tmem-freeze         Freeze tmem pools
    67. tmem-thaw           Thaw tmem pools
    68. tmem-set            Change tmem settings
    69. tmem-shared-auth    De/authenticate shared tmem pool
    70. tmem-freeable       Get information about how much freeable memory (MB) is in-use by tmem
    71. cpupool-create      Create a new CPU pool
    72. cpupool-list        List CPU pools on host
    73. cpupool-destroy     Deactivates a CPU pool
    74. cpupool-rename      Renames a CPU pool
    75. cpupool-cpu-add     Adds a CPU to a CPU pool
    76. cpupool-cpu-remove  Removes a CPU from a CPU pool
    77. cpupool-migrate     Moves a domain into a CPU pool
    78. cpupool-numa-split  Splits up the machine into one CPU pool per NUMA node
    79. getenforce          Returns the current enforcing mode of the Flask Xen security module
    80. setenforce          Sets the current enforcing mode of the Flask Xen security module
    81. loadpolicy          Loads a new policy int the Flask Xen security module
    82. remus               Enable Remus HA for domain
    83. devd                Daemon that listens for devices and launches backends
    84. psr-hwinfo          Show hardware information for Platform Shared Resource
    85. psr-cmt-attach      Attach Cache Monitoring Technology service to a domain
    86. psr-cmt-detach      Detach Cache Monitoring Technology service from a domain
    87. psr-cmt-show        Show Cache Monitoring Technology information
    88. psr-cat-cbm-set     Set cache capacity bitmasks(CBM) for a domain
    89. psr-cat-show        Show Cache Allocation Technology information
    复制代码
    1)xl list  显示Domain的相关信息
    1. [root@BAIYU_175 ~]# xl list
    2. Name                                        ID   Mem VCPUs  State   Time(s)  运行时间
    3. Domain-0                                     0  1024     2     r-----      65.2
    复制代码
    xen虚拟机状态:
    r: running
    b: 阻塞
    p: 暂停    #并不等同挂起,数据都在内存中没有保存在磁盘中
    s: 停止     #
    c: 崩溃
    d: dying, 正在关闭的过程中

    xl的其它常用命令
    shutdown: 关机
    reboot:重启
    pause: 暂停
    unpause: 解除暂停
    1. [root@BAIYU_175 ~]# xl pause -h
    2. Usage: xl [-vf] pause

    3. Pause execution of a domain.

    4. [root@BAIYU_175 ~]# xl pause --help
    5. Usage: xl [-vf] pause

    6. Pause execution of a domain.

    7. [root@BAIYU_175 ~]# xl pause  anyfish-001
    8. [root@BAIYU_175 ~]# xl list
    9. Name                                        ID   Mem VCPUs  State   Time(s)
    10. Domain-0                                     0  1024     2     r-----     125.8
    11. anyfish-001                                 10   256     2     --p---       4.2
    12. anyfish-002                                 12   256     2     -b----       8.7
    复制代码
    save: 将DomU的内存中的数据转存至指定的磁盘文件中;
    xl [-vf] save [options]   []
    restore: 从指定的磁盘文件中恢复DomU内存数据;
    xl [-vf] restore [options] []
    1. [root@BAIYU_175 ~]# xl save help
    2. 'xl save' requires at least 2 arguments.

    3. Usage: xl [-vf] save [options]   []

    4. Save a domain state to restore later.

    5. Options:

    6. -h  Print this help.
    7. -c  Leave domain running after creating the snapshot.
    8. -p  Leave domain paused after creating the snapshot.

    9. [root@BAIYU_175 ~]# xl save anyfish-002 /tmp/anyfish-002     
    10. Saving to /tmp/anyfish-002 new xl format (info 0x3/0x0/1024)
    11. xc: info: Saving domain 12, type x86 PV
    12. xc: Frames: 65536/65536  100%
    13. xc: End of stream: 0/0    0%

    14. [root@BAIYU_175 ~]# xl restore /tmp/anyfish-002   
    15. Loading new save file /tmp/anyfish-002 (new xl fmt info 0x3/0x0/1024)
    16. Savefile contains xl domain config in JSON format
    17. Parsing config from
    18. xc: info: Found x86 PV domain from Xen 4.6
    19. xc: info: Restoring domain
    20. xc: info: Restore successful
    21. xc: info: XenStore: mfn 0x22a3a, dom 0, evt 1
    22. xc: info: Console: mfn 0x22a39, dom 0, evt 2
    复制代码
    vcpu-list  列出虚拟cpu
    vcpu-pin  把虚拟cpu固定在物理核心上
    vcpu-set  设置虚拟机的活跃vcpu的个数
    1. [root@BAIYU_175 ~]# xl vcpu-list -h
    2. Usage: xl [-v] vcpu-list [Domain, ...]

    3. List the VCPUs for all/some domains.

    4. [root@BAIYU_175 ~]# xl vcpu-list
    5. Name                                ID  VCPU   CPU State   Time(s) Affinity(亲和) (Hard / Soft)
    6. Domain-0                             0     0    0   -b-     236.4  0 / all
    7. Domain-0                             0     1    1   r--     310.0  1 / all
    8. anyfish-002                         17     0    2   -b-       8.9  all / all
    9. anyfish-002                         17     1    0   -b-      10.5  all / all
    10. anyfish-001                         18     0    3   -b-      10.1  all / all
    11. anyfish-001                         18     1    2   -b-      10.8  all / all
    12.                                               #运行在哪个物理核心上
    复制代码
    info: 当前xen hypervisor的摘要信息
    domid
    domname

    top: 查看domain资源占用排序状态的命令

    network-list: 查看指定域使用网络及接口;
    network-attach:热插
    network-detach:热拔

    block-list: 查看指定域使用的块设备的列表;
    block-attach
    block-detach

    uptime: 运行时长

    三、如何创建xen pv模式
    1)kernel                          #DomU的内核文件可以放在Dom0中也可以放在DomU中
    2)initrd或initramfs         
    3)DomU内核模块
    4)根文件系统
    5)swap设备
    将上述内容定义在DomU的配置文件
    注意:xm与xl启动DomU使用的配置文件略有不同;
             xl.conf是xl命令的通用配置文件
             xl.cfg是启动某个DomU虚拟机的配置文件
    对于xl而言,其创建DomU使用的配置指令可通过“man xl.cfg”获取
    常用指令:
    name: 域惟一的名称
    builder:指明虚拟机的类型,generic表示pv,hvm表示hvm
            vcpus:虚拟cpu个数;
    maxcpus:最大虚拟cpu个数
    cpus:vcpu可运行于其上物理CPU列表
    memory=MBYTES: 内存大小
    maxmem=MBYTES:可以使用的最大内存空间
    on_poweroff:指明关机时采取的action
    destroy 断电, restart 重启, preserve 保留域
    on_reboot="ACTION": 指明“重启”DomU时采取的action
    on_crash="ACTION":虚拟机意外崩溃时采取的action
    uuid:DomU的惟一标识;     #不是必选项
    disk=[ "DISK_SPEC_STRING", "DISK_SPEC_STRING", ...]: 指明磁盘设备,列表,
    vif=[ "NET_SPEC_STRING", "NET_SPEC_STRING", ...]:指明网络接口,列表,
    vfb=[ "VFB_SPEC_STRING", "VFB_SPEC_STRING", ...]:指明virtual frame buffer(显示设备),列表;                             
    pci=[ "PCI_SPEC_STRING", "PCI_SPEC_STRING", ... ]: pci设备的列表

    PV模式专用指令:
    kernel="PATHNAME":内核文件路径,此为Dom0中的路径;
    ramdisk="PATHNAME":为kernel指定内核提供的ramdisk文件路径;
    root="STRING":指明根文件系统;
    extra="STRING":额外传递给内核引导时使用的参数;

      bootloader="PROGRAM":如果DomU使用自己的kernel及ramdisk,此时需要一个Dom0中的应用程序来实现其bootloader功能;

    磁盘参数指定方式:
    官方文档:http://xenbits.xen.org/docs/unst ... k-configuration.txt
    [, [, [, []]]]
    表示磁盘映像文件或设备文件路径:/images/xen/linux.img,/dev/myvg/linux
    表示磁盘格式,如果映像文件,有多种格式,例如raw, qcow, qcow2
    vdev: 此设备在DomU被识别为硬件设备类型,支持hd[x], xvd[x], sd[x]
    access: 访问权限,
    ro, r: 只读
    rw, w: 读写
    例如:
    disk=[ "/images/xen/linux.img,raw,xvda,rw", ]

    使用qemu-img管理磁盘映像:
    create [-f fmt] [-o options] filename [size]
                        -f 指明创建磁盘的格式
                        -o 特定格式支持的选项
    可创建sparse格式的磁盘映像文件,慢慢扩展到指定的大小

    2、创建一个pv格式的vm
    (1) 准备磁盘文件
           qemu-img create -f raw -o size=2G /images/xen/busybox.img
           mke2fs -t ext2 /images/xen/busybox.img
    1. [root@BAIYU_175 ~]# mkdir /images/xen/busybox.img -pv
    2. mkdir: 已创建目录 "/images"
    3. mkdir: 已创建目录 "/images/xen"
    4. mkdir: 已创建目录 "/images/xen/busybox.img"
    5. [root@BAIYU_175 ~]# qemu-img create -f raw -o size=2G /images/xen/busybox.img
    6. Formatting '/images/xen/busybox.img', fmt=raw size=2147483648
    7. [root@BAIYU_175 ~]# ls /images/xen/
    8. busybox.img
    9. [root@BAIYU_175 ~]# ll /images/xen/
    10. 总用量 0
    11. -rw-r--r-- 1 root root 2147483648 7月  14 23:52 busybox.img
    复制代码
    1. [root@BAIYU_175 xen]# mke2fs -t ext2 busybox.img   #为什么要用ext2格式?

    2. [root@BAIYU_175 xen]# du -sh busybox.img
    3. 97M busybox.img
    复制代码
    1. [root@BAIYU_175 xen]# mount -o loop /images/xen/busybox.img /mnt
    2. [root@BAIYU_175 xen]# ls /mnt
    3. lost+found
    复制代码
    (2) 提供根文件系统
    编译busybox,并复制到busybox.img映像中
    cp -a $BUSYBOX/_install/* /mnt
    mkdir /mnt/{proc,sys,dev,var}
    1. [root@BAIYU_175 busybox-1.22.1]# yum groupinstall "Development tools" "Server Platform Development"      #安装编译过程中可以用到的包
    2. [root@BAIYU_175 busybox-1.22.1]# yum install glibc-static   #为了方便移植busybox,把busybox编译成静态链接格式,不让它依赖额外的其它库,需要依赖这个包
    3. [root@BAIYU_175 busybox-1.22.1]# make menuconfig
    复制代码
    wKioL1eIYwrhBj2qAAB1C6UoL9U258.png
    勾选编译成静态链接格式
    1. [root@BAIYU_175 busybox-1.22.1]# make
    2. [root@BAIYU_175 busybox-1.22.1]# make install

    3. [root@BAIYU_175 busybox-1.22.1]# ls
    4. AUTHORS          Makefile.flags  applets        busybox_unstripped      debianutils  include     miscutils   scripts
    5. Config.in        Makefile.help   applets_sh     busybox_unstripped.map  docs         init        modutils    selinux
    6. INSTALL          README          arch           busybox_unstripped.out  e2fsprogs    libbb       networking  shell
    7. LICENSE          TODO            archival       configs                 editors      libpwdgrp   printutils  sysklogd
    8. Makefile         TODO_unicode    busybox        console-tools           examples     loginutils  procps      testsuite
    9. Makefile.custom  _install        busybox.links  coreutils               findutils    mailutils   runit       util-linux
    10. [root@BAIYU_175 busybox-1.22.1]# ls _install/     #默认安装的目录
    11. bin  linuxrc  sbin  usr
    复制代码
    复制文件到/mnt目录下
    1. [root@BAIYU_175 busybox-1.22.1]# cp -a _install/* /mnt
    2. [root@BAIYU_175 busybox-1.22.1]# ls /mnt
    3. bin  linuxrc  lost+found  sbin  usr
    4. [root@BAIYU_175 busybox-1.22.1]# cd /mnt
    5. [root@BAIYU_175 mnt]# mkdir proc sys dev etc var boot home
    6. [root@BAIYU_175 mnt]# ll
    7. total 56
    8. drwxr-xr-x 2 root root  4096 Jul 15 12:22 bin
    9. drwxr-xr-x 2 root root  4096 Jul 15 12:25 boot
    10. drwxr-xr-x 2 root root  4096 Jul 15 12:25 dev          #一定需要
    11. drwxr-xr-x 2 root root  4096 Jul 15 12:25 etc          #一定需要
    12. drwxr-xr-x 2 root root  4096 Jul 15 12:25 home
    13. lrwxrwxrwx 1 root root    11 Jul 15 12:22 linuxrc -> bin/busybox
    14. drwx------ 2 root root 16384 Jul 15 11:01 lost+found
    15. drwxr-xr-x 2 root root  4096 Jul 15 12:25 proc         #一定需要
    16. drwxr-xr-x 2 root root  4096 Jul 15 12:22 sbin
    17. drwxr-xr-x 2 root root  4096 Jul 15 12:25 sys          #一定需要
    18. drwxr-xr-x 4 root root  4096 Jul 15 12:22 usr
    19. drwxr-xr-x 2 root root  4096 Jul 15 12:25 var

    20. [root@BAIYU_175 mnt]# chroot /mnt /bin/sh
    21. / # ls
    22. bin         dev         home        lost+found  sbin        usr
    23. boot        etc         linuxrc     proc        sys         var
    24. / # ls boot/
    25. / # ls dev
    26. / # exit                   #能正常使用说明这个根文件系统创建成功
    复制代码
    (3) 提供配置DomU配置文件
    name = "busybox-001"
    kernel = "/boot/vmlinuz"
    ramdisk = "/boot/initramfs.img"
    extra = "selinux=0 init=/bin/sh"
    memory = 256
    vcpus = 2
    disk = [ '/images/xen/busybox.img,raw,xvda,rw' ]
    root = "/dev/xvda ro"
    1. [root@BAIYU_175 ~]# cd /boot
    2. [root@BAIYU_175 boot]# ll
    3. total 76456
    4. -rw-r--r--. 1 root root  2585052 Jul 24  2015 System.map-2.6.32-573.el6.x86_64
    5. -rw-r--r--  1 root root  3208657 May 27 20:18 System.map-3.18.34-20.el6.x86_64
    6. -rw-r--r--. 1 root root   107134 Jul 24  2015 config-2.6.32-573.el6.x86_64
    7. -rw-r--r--  1 root root   155205 May 27 20:18 config-3.18.34-20.el6.x86_64
    8. drwxr-xr-x. 3 root root     4096 Oct 24  2015 efi
    9. drwxr-xr-x. 2 root root     4096 Jul 14 23:47 grub
    10. -rw-------. 1 root root 27609239 Oct 24  2015 initramfs-2.6.32-573.el6.x86_64.img
    11. -rw-------  1 root root 29366666 Jul 14 18:07 initramfs-3.18.34-20.el6.x86_64.img
    12. -rw-------  1 root root  4330884 Jan  2  2016 initrd-2.6.32-573.el6.x86_64kdump.img
    13. drwx------. 2 root root    16384 Oct 24  2015 lost+found
    14. -rw-r--r--. 1 root root   205998 Jul 24  2015 symvers-2.6.32-573.el6.x86_64.gz
    15. -rw-r--r--  1 root root   285315 May 27 20:18 symvers-3.18.34-20.el6.x86_64.gz
    16. -rwxr-xr-x. 1 root root  4220560 Jul 24  2015 vmlinuz-2.6.32-573.el6.x86_64
    17. -rwxr-xr-x  1 root root  5267744 May 27 20:18 vmlinuz-3.18.34-20.el6.x86_64
    18. -rw-r--r--  1 root root   893598 May 26 18:58 xen-4.6.1-11.el6.gz
    19. lrwxrwxrwx  1 root root       19 Jul 14 18:06 xen-4.6.gz -> xen-4.6.1-11.el6.gz
    20. lrwxrwxrwx  1 root root       19 Jul 14 18:06 xen.gz -> xen-4.6.1-11.el6.gz
    21. [root@BAIYU_175 boot]# ln -sv vmlinuz-2.6.32-573.el6.x86_64 vmlinuz
    22. `vmlinuz' -> `vmlinuz-2.6.32-573.el6.x86_64'
    23. [root@BAIYU_175 boot]# ln -sv initramfs-2.6.32-573.el6.x86_64.img  initramfs.img
    24. `initramfs.img' -> `initramfs-2.6.32-573.el6.x86_64.img'
    25. [root@BAIYU_175 boot]# ll
    26. total 76456
    27. -rw-r--r--. 1 root root  2585052 Jul 24  2015 System.map-2.6.32-573.el6.x86_64
    28. -rw-r--r--  1 root root  3208657 May 27 20:18 System.map-3.18.34-20.el6.x86_64
    29. -rw-r--r--. 1 root root   107134 Jul 24  2015 config-2.6.32-573.el6.x86_64
    30. -rw-r--r--  1 root root   155205 May 27 20:18 config-3.18.34-20.el6.x86_64
    31. drwxr-xr-x. 3 root root     4096 Oct 24  2015 efi
    32. drwxr-xr-x. 2 root root     4096 Jul 15 13:57 grub
    33. -rw-------. 1 root root 27609239 Oct 24  2015 initramfs-2.6.32-573.el6.x86_64.img
    34. -rw-------  1 root root 29366666 Jul 14 18:07 initramfs-3.18.34-20.el6.x86_64.img
    35. lrwxrwxrwx  1 root root       35 Jul 15 13:59 initramfs.img -> initramfs-2.6.32-573.el6.x86_64.img
    36. -rw-------  1 root root  4330884 Jan  2  2016 initrd-2.6.32-573.el6.x86_64kdump.img
    37. drwx------. 2 root root    16384 Oct 24  2015 lost+found
    38. -rw-r--r--. 1 root root   205998 Jul 24  2015 symvers-2.6.32-573.el6.x86_64.gz
    39. -rw-r--r--  1 root root   285315 May 27 20:18 symvers-3.18.34-20.el6.x86_64.gz
    40. lrwxrwxrwx  1 root root       29 Jul 15 13:57 vmlinuz -> vmlinuz-2.6.32-573.el6.x86_64
    41. -rwxr-xr-x. 1 root root  4220560 Jul 24  2015 vmlinuz-2.6.32-573.el6.x86_64
    42. -rwxr-xr-x  1 root root  5267744 May 27 20:18 vmlinuz-3.18.34-20.el6.x86_64
    43. -rw-r--r--  1 root root   893598 May 26 18:58 xen-4.6.1-11.el6.gz
    44. lrwxrwxrwx  1 root root       19 Jul 14 18:06 xen-4.6.gz -> xen-4.6.1-11.el6.gz
    45. lrwxrwxrwx  1 root root       19 Jul 14 18:06 xen.gz -> xen-4.6.1-11.el6.gz
    复制代码
    根据xen给定的pv示例配置文件修改:
    1. [root@BAIYU_175 boot]# cd /etc/xen/
    2. [root@BAIYU_175 xen]# ls
    3. auto  cpupool  scripts  xl.conf  xlexample.hvm  xlexample.pvlinux
    4. [root@BAIYU_175 xen]# cp xlexample.pvlinux busybox

    5. [root@BAIYU_175 xen]# grep -v '^#\|^
    6. (4) 启动实例
    7. xl [-v] create <DomU_Config_file> -n
    8. xl create <DomU_Config_file> -c
    9. <div class="blockcode"><blockquote>[root@BAIYU_175 xen]# xl help create
    10. Usage: xl [-vfN] create <ConfigFile> [options] [vars]
    11. #-v 表示详细信息,
    12. -f 指定xl命令的配置文件
    13. ConfigFile  是DomU的配置文件
    14. Create a domain from config file <filename>.

    15. Options:

    16. -h                      Print this help.
    17. -p                      Leave the domain paused after it is created.
    18. -c                      Connect to the console after the domain is created.
    19. -f FILE, --defconfig=FILE
    20.                      Use the given configuration file.
    21. -q, --quiet             Quiet.
    22. -n, --dryrun            Dry run - prints the resulting configuration   #并不真正创建虚拟机,只是空跑一遍,就是测试咯,
    23.                          (deprecated in favour of global -N option).
    24. -d                      Enable debug messages.        
    25. -F                      Run in foreground until death of the domain.
    26. -e                      Do not wait in the background for the death of the domain.
    27. -V, --vncviewer         Connect to the VNC display after the domain is created.
    28. -A, --vncviewer-autopass
    29.                         Pass VNC password to viewer via stdin.
    30.                                           
    31. [root@BAIYU_175 ~]# umount /mnt   
    32. [root@BAIYU_175 xen]# xl -v create /etc/xen/busybox  
    33. [root@BAIYU_175 xen]# xl list
    34. Name                                        ID   Mem VCPUs  State   Time(s)
    35. Domain-0                                     0  1024     2     r-----      85.7
    36. anyfish-001                                 24   256     2     -b----       1.4
    37. [root@BAIYU_175 xen]# xl console anyfish-001    #连接虚拟控制台
    38. / # ls
    39. bin         dev         home        lost+found  sbin        usr
    40. boot        etc         linuxrc     proc        sys         var             按crtl + ]退回到Dom0,输入exit会删除掉anyfish-001这个虚拟机
    复制代码
    (5)添加网卡
    如何配置网络接口?
    vif = [ '<vifspec>', '<vifspec>', ... ]
    vifspec:  [<key>=<value>|<flag>,]
    常用的key:
    mac=:指定mac地址,要以“00:16:3e”开头;
    bridge=<bridge>:指定此网络接口在Dom0被关联至哪个桥设备上;
    model=<MODEL>:
            vifname=: 接口名称,在Dom0中显示的名称;
    script=:执行的脚本;
    ip=:指定ip地址,会注入到DomU中;
    rate=: 指明设备传输速率,通常为"#UNIT/s"格式
    UNIT: GB, MB, KB, B for bytes.
      Gb, Mb, Kb, b for bits.
    1)创建xenbr0
    # brctl addbr br0
    # brctl stp br0 on
    # ifconfig eth0 0 up
    # brctl addif br0 eth0
    # ifconfig br0 IP/NETMASK up
    # route add default gw GW
    1. [root@BAIYU_175 ~]# brctl show
    2. bridge name    bridge id      STP enabled    interfaces
    3. xenbr0      8000.000c29efbbd4   yes     eth0
    4. #在这步后,系统死机了,可能3.18的内核bridge功能有bug,用3.7.4版本的内核没问题
    复制代码
    2)在配置文件/etc/xen/busybox中添天网卡相关配置,并复制驱动程序到DomU中
    1. vif = [ 'bridge=xenbr0' ]
    复制代码
    1. [root@BAIYU_175 ~]# cd /lib/modules/2.6.32-573.el6.x86_64/kernel/drivers/  #驱动文件的路径
    2. [root@BAIYU_175 drivers]# ls
    3. acpi        char      gpio        infiniband  mfd      platform   serial   vhost
    4. ata         cpufreq   gpu         input       misc     power      ssb      video
    5. atm         crypto    hid         isdn        mmc      powercap   staging  virtio
    6. auxdisplay  dca       hv          leds        mtd      pps        target   watchdog
    7. bcma        dma       hwmon       md          net      ptp        thermal  xen
    8. block       edac      i2c         media       parport  regulator  uio
    9. bluetooth   firewire  idle        memstick    pci      rtc        usb
    10. cdrom       firmware  ieee802154  message     pcmcia   scsi       uwb
    11. [root@BAIYU_175 drivers]# cd net/
    12. [root@BAIYU_175 net]# ls
    13. 3c59x.ko     cnic.ko       ifb.ko         netxen          r6040.ko       tg3.ko
    14. 8139cp.ko    cxgb3         igb            niu.ko          r8169.ko       tlan.ko
    15. 8139too.ko   cxgb4         igbvf          ns83820.ko      s2io.ko        tulip
    16. 8390.ko      cxgb4vf       ipg.ko         pch_gbe         sc92031.ko     tun.ko
    17. acenic.ko    dl2k.ko       ixgb           pcmcia          sfc            typhoon.ko
    18. amd8111e.ko  dnet.ko       ixgbe          pcnet32.ko      sis190.ko      usb
    19. atl1c        dummy.ko      ixgbevf        phy             sis900.ko      veth.ko
    20. atl1e        e1000         jme.ko         ppp_async.ko    skge.ko        via-rhine.ko
    21. atlx         e1000e        macvlan.ko     ppp_deflate.ko  sky2.ko        via-velocity.ko
    22. b44.ko       e100.ko       macvtap.ko     ppp_generic.ko  slhc.ko        virtio_net.ko
    23. benet        enic          mdio.ko        ppp_mppe.ko     slip.ko        vmxnet3
    24. bna          epic100.ko    mii.ko         pppoe.ko        smsc9420.ko    vxge
    25. bnx2.ko      ethoc.ko      mlx4           pppol2tp.ko     starfire.ko    vxlan.ko
    26. bnx2x        fealnx.ko     mlx5           pppox.ko        sundance.ko    wan
    27. bonding      forcedeth.ko  myri10ge       ppp_synctty.ko  sungem.ko      wimax
    28. can          hyperv        natsemi.ko     qla3xxx.ko      sungem_phy.ko  wireless
    29. cassini.ko   i40e          ne2k-pci.ko    qlcnic          sunhme.ko      xen-netfront.ko
    30. chelsio      i40evf        netconsole.ko  qlge            tehuti.ko
    31. [root@BAIYU_175 net]# modinfo xen-netfront.ko  
    32. filename:       xen-netfront.ko
    33. alias:          xennet
    34. alias:          xen:vif
    35. license:        GPL
    36. description:    Xen virtual network device frontend
    37. srcversion:     5C6FC78BC365D9AF8135201
    38. depends:           #查看此模块依赖的模块,如果有要一起复制过去
    39. vermagic:       2.6.32-573.el6.x86_64 SMP mod_unload modversions
    40. [root@BAIYU_175 net]# cp xen-netfront.ko /mnt/l
    41. linuxrc     lost+found/
    42. [root@BAIYU_175 net]# cp xen-netfront.ko /mnt/l
    43. linuxrc     lost+found/
    44. [root@BAIYU_175 net]# mkdir -pv /mnt/lib/modules
    45. mkdir: 已创建目录 "/mnt/lib"
    46. mkdir: 已创建目录 "/mnt/lib/modules"
    47. [root@BAIYU_175 net]# cp xen-netfront.ko /mnt/lib/modules
    48. mkdir: 已创建目录 "/mnt/lib/modules"
    49. [root@BAIYU_175 net]# cp xen-netfront.ko /mnt/lib/modules
    50. [root@BAIYU_175 net]# umount /mnt
    51. [root@BAIYU_175 net]# xl create /etc/xen/busybox -c
    52. / # insmod /lib/modules/xen-netfront.ko                  #手动装载驱动程序
    53. Initialising Xen virtual ethernet driver.
    54. / # ifconfig
    55. / # ifconfig -a
    56. eth0      Link encap:Ethernet  HWaddr 00:16:3E:50:D3:20  
    57.           BROADCAST MULTICAST  MTU:1500  Metric:1
    58.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    59.           TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
    60.           collisions:0 txqueuelen:1000
    61.           RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
    62.           Interrupt:18

    63. lo        Link encap:Local Loopback  
    64.           LOOPBACK  MTU:65536  Metric:1
    65.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    66.           TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
    67.           collisions:0 txqueuelen:0
    68.           RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
    复制代码
    此时在Dom0上也可以看到虚拟机网卡的后半段
    1. [root@BAIYU_175 ~]# xl list
    2. Name                                        ID   Mem VCPUs  State   Time(s)
    3. Domain-0                                     0  1024     2     r-----      78.6
    4. anyfish-001                                  9   256     2     -b----       3.0
    5. [root@BAIYU_175 ~]# brctl show
    6. bridge name    bridge id      STP enabled    interfaces
    7. xenbr0      8000.000c29efbbd4   yes     eth0
    8.                             vif9.0
    9. [root@BAIYU_175 ~]# ifconfig
    10. eth0      Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:D4  
    11.           inet6 addr: fe80::20c:29ff:feef:bbd4/64 Scope:Link
    12.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    13.           RX packets:20797 errors:0 dropped:0 overruns:0 frame:0
    14.           TX packets:563 errors:0 dropped:0 overruns:0 carrier:0
    15.           collisions:0 txqueuelen:1000
    16.           RX bytes:1332243 (1.2 MiB)  TX bytes:62352 (60.8 KiB)

    17. eth1      Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:DE  
    18.           inet addr:172.16.11.199  Bcast:172.16.11.255  Mask:255.255.255.0
    19.           inet6 addr: fe80::20c:29ff:feef:bbde/64 Scope:Link
    20.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    21.           RX packets:26507 errors:0 dropped:0 overruns:0 frame:0
    22.           TX packets:3142 errors:0 dropped:0 overruns:0 carrier:0
    23.           collisions:0 txqueuelen:1000
    24.           RX bytes:2899642 (2.7 MiB)  TX bytes:457705 (446.9 KiB)

    25. lo        Link encap:Local Loopback  
    26.           inet addr:127.0.0.1  Mask:255.0.0.0
    27.           inet6 addr: ::1/128 Scope:Host
    28.           UP LOOPBACK RUNNING  MTU:65536  Metric:1
    29.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    30.           TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
    31.           collisions:0 txqueuelen:0
    32.           RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)

    33. vif9.0    Link encap:Ethernet  HWaddr FE:FF:FF:FF:FF:FF    #9是虚拟机的ID号,.0表示第一块网卡
    34.           inet6 addr: fe80::fcff:ffff:feff:ffff/64 Scope:Link
    35.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    36.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    37.           TX packets:46 errors:0 dropped:0 overruns:0 carrier:0
    38.           collisions:0 txqueuelen:32
    39.           RX bytes:0 (0.0 b)  TX bytes:2548 (2.4 KiB)

    40. xenbr0    Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:D4  
    41.           inet addr:192.168.100.175  Bcast:192.168.100.255  Mask:255.255.255.0
    42.           inet6 addr: fe80::20c:29ff:feef:bbd4/64 Scope:Link
    43.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    44.           RX packets:727 errors:0 dropped:0 overruns:0 frame:0
    45.           TX packets:292 errors:0 dropped:0 overruns:0 carrier:0
    46.           collisions:0 txqueuelen:0
    47.           RX bytes:55541 (54.2 KiB)  TX bytes:18796 (18.3 KiB)

    48. #DomU上,
    49. / # ping 192.168.100.180
    50. PING 192.168.100.180 (192.168.100.180): 56 data bytes
    51. ping: sendto: Network is unreachable
    52. / # ifconfig eth0 192.168.100.181
    53. / # ping 192.168.100.180
    54. PING 192.168.100.180 (192.168.100.180): 56 data bytes
    55. 64 bytes from 192.168.100.180: seq=0 ttl=64 time=16.589 ms
    56. 64 bytes from 192.168.100.180: seq=1 ttl=64 time=0.912 ms
    复制代码
    上面这种方式创建的网卡是桥接,那我们怎么创建一个虚拟通道呢(相当于VMware Workstation网卡设置中的VMnet1,...VMnet19)
    1. [root@BAIYU_175 ~]# xl list
    2. Name                                        ID   Mem VCPUs  State   Time(s)
    3. Domain-0                                     0  1024     2     r-----     100.7
    4. anyfish-001                                  9   256     2     -b----      12.5
    5. [root@BAIYU_175 ~]# xl destroy anyfish-001  #立即终止域,相当于拔电源
    6. [root@BAIYU_175 ~]# xl list
    7. Name                                        ID   Mem VCPUs  State   Time(s)
    8. Domain-0                                     0  1024     2     r-----     101.4
    9. [root@BAIYU_175 ~]# cp /images/xen/busybox.img /images/xen/busybox2.img
    10. [root@BAIYU_175 ~]# ls /etc/xen/
    11. auto     busybox.orig  scripts  vm2.orig  xlexample.hvm
    12. busybox  cpupool       vm2      xl.conf   xlexample.pvlinux
    13. [root@BAIYU_175 ~]# brctl add xenbr1
    14. [root@BAIYU_175 ~]# ifconfig xenbr1 up
    15. [root@BAIYU_175 ~]# ifconfig
    16. eth0      Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:D4  
    17.           inet6 addr: fe80::20c:29ff:feef:bbd4/64 Scope:Link
    18.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    19.           RX packets:30305 errors:0 dropped:0 overruns:0 frame:0
    20.           TX packets:4219 errors:0 dropped:0 overruns:0 carrier:0
    21.           collisions:0 txqueuelen:1000
    22.           RX bytes:2008392 (1.9 MiB)  TX bytes:387507 (378.4 KiB)

    23. eth1      Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:DE  
    24.           inet addr:172.16.11.199  Bcast:172.16.11.255  Mask:255.255.255.0
    25.           inet6 addr: fe80::20c:29ff:feef:bbde/64 Scope:Link
    26.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    27.           RX packets:34311 errors:0 dropped:0 overruns:0 frame:0
    28.           TX packets:3552 errors:0 dropped:0 overruns:0 carrier:0
    29.           collisions:0 txqueuelen:1000
    30.           RX bytes:3744076 (3.5 MiB)  TX bytes:501793 (490.0 KiB)

    31. lo        Link encap:Local Loopback  
    32.           inet addr:127.0.0.1  Mask:255.0.0.0
    33.           inet6 addr: ::1/128 Scope:Host
    34.           UP LOOPBACK RUNNING  MTU:65536  Metric:1
    35.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    36.           TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
    37.           collisions:0 txqueuelen:0
    38.           RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)

    39. xenbr0    Link encap:Ethernet  HWaddr 00:0C:29:EF:BB:D4  
    40.           inet addr:192.168.100.175  Bcast:192.168.100.255  Mask:255.255.255.0
    41.           inet6 addr: fe80::20c:29ff:feef:bbd4/64 Scope:Link
    42.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    43.           RX packets:2656 errors:0 dropped:0 overruns:0 frame:0
    44.           TX packets:994 errors:0 dropped:0 overruns:0 carrier:0
    45.           collisions:0 txqueuelen:0
    46.           RX bytes:163430 (159.5 KiB)  TX bytes:111633 (109.0 KiB)

    47. xenbr1    Link encap:Ethernet  HWaddr 42:5B:43:45:2B:D2  
    48.           inet6 addr: fe80::405b:43ff:fe45:2bd2/64 Scope:Link
    49.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
    50.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    51.           TX packets:2 errors:0 dropped:0 overruns:0 carrier:0
    52.           collisions:0 txqueuelen:0
    53.           RX bytes:0 (0.0 b)  TX bytes:168 (168.0 b)

    54. [root@BAIYU_175 ~]# cp /etc/xen/busybox /etc/xen/busybox2
    55. [root@BAIYU_175 xen]# vi busybox
    56. [root@BAIYU_175 xen]# grep -v '^#\|^

    57. 此时虚拟通道创建完成,虚拟机之间可以互相通信,而虚拟机不能和物理机及外界通信










    58. busybox      #修改后的配置参数
    59. name = "anyfish-001"
    60. kernel = "/boot/vmlinuz"
    61. ramdisk = "/boot/initramfs.img"
    62. extra = "selinux=0 init=/bin/sh"
    63. memory = 521
    64. vcpus = 2
    65. vif = [ '' ]
    66. disk = [ '/images/xen/busybox.img,raw,xvda,rw' ]
    67. root = "/dev/xvda ro"
    复制代码
    (4) 启动实例
    xl [-v] create <DomU_Config_file> -n
    xl create <DomU_Config_file> -c
    [        DISCUZ_CODE_17        ]
    (5)添加网卡
    如何配置网络接口?
    vif = [ '<vifspec>', '<vifspec>', ... ]
    vifspec:  [<key>=<value>|<flag>,]
    常用的key:
    mac=:指定mac地址,要以“00:16:3e”开头;
    bridge=<bridge>:指定此网络接口在Dom0被关联至哪个桥设备上;
    model=<MODEL>:
            vifname=: 接口名称,在Dom0中显示的名称;
    script=:执行的脚本;
    ip=:指定ip地址,会注入到DomU中;
    rate=: 指明设备传输速率,通常为"#UNIT/s"格式
    UNIT: GB, MB, KB, B for bytes.
      Gb, Mb, Kb, b for bits.
    1)创建xenbr0
    # brctl addbr br0
    # brctl stp br0 on
    # ifconfig eth0 0 up
    # brctl addif br0 eth0
    # ifconfig br0 IP/NETMASK up
    # route add default gw GW
    [        DISCUZ_CODE_18        ]
    2)在配置文件/etc/xen/busybox中添天网卡相关配置,并复制驱动程序到DomU中
    [        DISCUZ_CODE_19        ]
    [        DISCUZ_CODE_20        ]
    此时在Dom0上也可以看到虚拟机网卡的后半段
    [        DISCUZ_CODE_21        ]
    上面这种方式创建的网卡是桥接,那我们怎么创建一个虚拟通道呢(相当于VMware Workstation网卡设置中的VMnet1,...VMnet19)
    [        DISCUZ_CODE_22        ]

    此时虚拟通道创建完成,虚拟机之间可以互相通信,而虚拟机不能和物理机及外界通信








    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部