《Linux上的虚拟化技术Xen初学者指南精品资料.doc》由会员分享,可在线阅读,更多相关《Linux上的虚拟化技术Xen初学者指南精品资料.doc(25页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Linux上的虚拟化技术 Xen 初学者指南1、什么是Xen;Xen是一个开放源代码的para-virtualizing虚拟机(VMM),或“管理程序”,是为x86架构的机器而设计的。Xen可以在一套物理硬件上安全的执行多个虚拟机;Xen是基于内核的虚拟程序,它和操作平台结合的极为密切,所以它占用的资源最少。什么是虚拟机呢?可能大家知道VMWARE吧,是的,Xen就是类似这样的程序,比如我们可以在Fedora上虚拟安装和使用Slackware、Debian、Gentoo . .等发行版。因为Xen是基于内核的,相对VMWARE来说,它占用的系统资源也就是VMWARE的百分之几左右。Xen是不是
2、更有优势呢?只有您实践了才知道。这也是我写本文的最主要原因;1.1 Xen的特性;虚拟机的性能更接近真实硬件环境)在真实物理环境的平台和虚拟平台间自由切换)在每个客户虚拟机支持到32个虚拟CPU,通过VCPU热插拔)支持PAE指令集的x86/32, x86/64平台通过Intel虚拟支持VT的支持来用虚拟原始操作系统(未经修改的)支持(包括Microsoft Windows)优秀的硬件支持.支持几乎所有的Linux设备驱动1.2 Xen的应用范围;服务器整合:在虚拟机范围内,在一台物理主机上安装多个服务器,用于演示及故障隔绝;无硬件依赖:允许应用程序和操作系统对新硬件的移值测试;多操作系统配置
3、:以开发和测试为目的,同时运行多个操作系统;内核开发:在虚拟机的沙盒中,做内核的测试和调试,无需为了测试而单独架设一*立的机器;集群运算:和单独的管理每个物理主机相比较,在VM级管理更加灵活,在负载均衡方面,更易于控制,和隔离;为客户操作系统提供硬件技术支持:可以开发新的操作系统,以得益于现存操作系统的广泛硬件支持,比如Linux;1.3 Xen的操作系统支持和硬件支持;请参阅: Xen v3.0用户手册2、Xen的一点理论基础;基于Xen的操作系统,有多个层,最底层和最高特权层是Xen程序本身。Xen可以管理多个客户操作系统,每个操作系统都能在一个安全的虚拟机中实现。在Xen的术语中,Dom
4、ain由Xen控制,以高效的利用CPU的物理资源。每个客户操作系统可以管理它自身的应用。这种管理包括每个程序在规定时间内的响应到执行,是通过Xen调度到虚拟机中实现。当Xen启动运行后,第一个虚拟的操作系统,就是Xen本身,我们通过xm list,会发现有一个Domain 0的虚拟机。Domain 0 是其它虚拟主机的管理者和控制者,Domain 0 可以构建其它的更多的Domain ,并管理虚拟设备。它还能执行管理任务,比如虚拟机的体眠、唤醒和迁移其它虚拟机。一个被称为xend的服务器进程通过domain 0来管理系统,Xend负责管理众多的虚拟主机,并且提供进入这些系统的控制台。命令经一个
5、命令行的工具通过一个HTTP的接口被传送到xend。3、Xen的安装;在写本文时,Xen的当前最新版本是xen-3.0.1,它基于的内核版本是2.6.12.6的。您可以根据自己的操作系统的情况来选择一种安装方式,适合您的就是最好的;3.1安装Xen的准备工作;拥有GRUB引导的Linux做为安装平台,还要编译工具,比如gcc、binutils及make和automake等;开发库有zlib和python-dev等;具体明细请参阅: Xen v3.0用户手册由于Xen用Python开发的,所以Python当然也是必不可少的。如果您是新手,我建议您用自己所用的操作系统软件包管理工具来安装这些软件包
6、。3.2在Redhat/Fedora操作平台上的安装;在Fedora/Redhat平台上安装比较简单,您可以通过yum来在线安装Xen和支持Xen的内核;因为Fedora/Redhat已经提供对Xen的支持了;Fedora/Redhat提供的Xen内核支持比较高;不过就目前我的测试来看好象经常会机器重启,存在的问题可能是桌面环境造成的,比如GNOME桌面,打开就有重启的现象,也可能是Fedora/Redhat提供的Xen内有BUG;安装Xen及支持Xen的请参考:Fedora Core 5.0用 Xen虚拟Slackware 10.2对于Fedora 4.0及Redhat和Fedora 5.0
7、类似;现在Yum的源上都有Xen和支持Xen的内核包;3.3通过Xen的二进制包来安装(几乎适用所有的Linux发行版);通过Xen的二进制软件包来安装,这应该是通用的,几乎适合所有的Linux操作系统。由于二进制所是已经编译好的,我已经在Slackware平台上用这种方法来安装,还是成功的。另外etony兄也在Debian上安装成功;您应该到下载好后,就解压安装,我们还是以支持x86_32构架机器的xen-3.0.1-install-x86_32.tgz为例:rootlocalhost # tar zxvf xen-3.0.1-install-x86_32.tgzrootlocalhost
8、# cd xen-3.0.1-installrootlocalhost xen-3.0.1-install# sh install.sh判断是不是安装好了,请查看/boot目录,会发现有很多文件名带有xen字样的文件,另外在/lib/moudules中也会发现有支持xen的内核模块;另外再看一看是否有/etc/xen这个目录。我想应该是有的。3.4通过Xen的源码包编译安装(仅供参考);通过Xen的二进制包来安装,可能有时内核不太适应我们的需要,这时我们要通过Xen的源码包来安装。通过自己编译来安装Xen及支持Xen的内核;Xen的源码包,您可以到3.41编译原理;通过Xen的源码包编译,其实
9、也没有什么神秘的。在Xen的源码包中提供了一些内核补丁和内核配置文件等。当我们执行编译命令时,首先编译的是Xen程序本身,然后是编译内核。在编译内核时,程序会自动判断是否有内核源码,xen-3.0.1支持的内核是2.6.12.6,如果在xen的解压目录下没有,他就会自动内核的官方站http:/www.kernel.org下载linux-2.6.12.tar.bz2。然后就是自动解压并为此内核打补丁。然后系统会根据指令要求,然后采用相应的内核配置文件,或配置内核进行编译。3.42编译过程简说;第一步:解压软件包,查看Xen源码包所带的文件;rootlocalhost # tar zxvf xen
10、-3.0.1-src.tgzrootlocalhost # cd xen-3.0.1rootlocalhost xen-3.0.1# lsCOPYING Config.mk README docs install.sh patches xenChangeLog Makefile buildconfigs extras linux-2.6-xen-sparse tools我们解压xen-3.0.1-src.tgz后,进入解压目录,会看到以上的文件或文件夹。patches是内核的补丁包,linux-2.6-xen-sparse是支持Xen的内核目录树,值得注意的是内核的配置文件就在这个目录中;ro
11、otlocalhost xen-3.0.1# ls linux-2.6-xen-sparse/arch/xen/configs/xen0_defconfig_ia64 xen0_defconfig_x86_64 xenU_defconfig_x86_32 xen_defconfig_x86_32xen0_defconfig_x86_32 xenU_defconfig_ia64 xenU_defconfig_x86_64 xen_defconfig_x86_64看到上面所列出的内核配置文件了吧,我们可能会发现文件名带有xen0字样的和xenU字样的两类文件。在这两类内核中,我们大多会修改的内核配
12、置文件是运行xen的操作系统的内核配置文件,另一个是用于虚拟操作系统的内核配置文件;xen0字样的就是我们一般是用于我们运行xen的操作系统的内核,而xenU字样的就是为虚拟操作系统所提供的内核。另外还有x86_32和x86_64之分,这表示CPU的架构。比如我们用的是x86架构32位的CPU,我们在编译内核的时候就要用到xen0_defconfig_x86_32和xenU_defconfig_x86_32配置文件。举个例子:比如我的机器架构是x86_32位的,我安装xen的操作系统是Slackware,我想在Slackware虚拟Debian 、Gentoo、Fedora等操作系统。这时编译
13、虚拟平台Slackware所用的内核的配置文件就是xen0_defconfig_x86_32 ,而被虚拟平台(Debian 、Gentoo、Fedora等操作系统)所用的内核就是xenU_defconfig_x86_32 。弄明白内核配置文件有何用?我们能明白xen在编译过程中用了哪些内核配置文件,目的是我们在编译过程中可以根据自己的需要来修改它,以编译出适合我们需要的内核。比如我们想让Slackware支持xen,并且还要支持NTFS文件系统;所以我们就要修改xen0_defconfig_x86_32这个文件。找出如下一行;# CONFIG_NTFS_FS is not set改为CONFI
14、G_NTFS_FS=m如果您想让被虚拟的操作系统(Debian 、Gentoo、Fedora等)也支持NTFS文件系统,所以要在xenU_defconfig_x86_32找出如下一行;# CONFIG_NTFS_FS is not set改为CONFIG_NTFS_FS=m第二步:配置内核;这一步有两种方法,一个是直接修改内核配置文件,另一个是内核配置界面来配置;方法一:通过修改内核配置文件;Xen所带的内核配置文件位于解压目录中的linux-2.6-xen-sparse/arch/xen/configs 。我们前面已经提到了相关配置文件的用途。请仔细看前一步的说明;方法二:通过内核配置界面来
15、配置;rootlocalhost xen-3.0.1# make linux-2.6-xen0-config CONFIGMODE=menuconfig第三步:编译和安装Xen;rootlocalhost xen-3.0.1# makerootlocalhost xen-3.0.1# make install3.43创建initrd文件;有的系统需要initrd-XXXX.img或initrd.gz文件才能引导起来,如果您的系统用了支持xen的支持引导不起来,就要创建一个initrd-XXXX.img或initrd.gz的文件;请参考: Xen v3.0用户手册3.44关于xen0和xenU内
16、核说明;一般的情况下会在/boot目录中有两个与xen相关的内核,有的文件名带有vmlinuz-XXXX-xen0字样的,有的带有vmlinuz-XXXX-xenU字样的;比如:rootlocalhost xen-3.0.1# ls -la /boot/vmlinuz*xen*lrwxrwxrwx 1 root root 21 2006-04-12 07:42 /boot/vmlinuz-2.6-xen0 - vmlinuz-2.6.12.6-xen0lrwxrwxrwx 1 root root 21 2006-04-12 07:49 /boot/vmlinuz-2.6-xenU - vmli
17、nuz-2.6.12.6-xenUlrwxrwxrwx 1 root root 21 2006-04-12 07:42 /boot/vmlinuz-2.6.12-xen0 - vmlinuz-2.6.12.6-xen0lrwxrwxrwx 1 root root 21 2006-04-12 07:49 /boot/vmlinuz-2.6.12-xenU - vmlinuz-2.6.12.6-xenU-rw-r-r- 1 root root 2180524 2006-04-12 07:42 /boot/vmlinuz-2.6.12.6-xen0-rw-r-r- 1 root root 11299
18、50 2006-04-12 07:49 /boot/vmlinuz-2.6.12.6-xenU其实就是两个与xen相关的内核,其它的都是这两个内核文件的链接;也就是vmlinuz-2.6.12.6-xen0和vmlinuz-2.6.12.6-xenU。vmlinuz-2.6.12.6-xen0是用来引导虚拟平台的,比如我们在Slackware上安装Xen,那Slackware就是虚拟平台;所以如果要让Slackware的xen能运行起来,必须用xen相关的内核,也就是vmlinuz-2.6.12.6-xen0这个内核。而XenU字样这个内核,是用来引导虚拟操作系统用的,我们在以后会提到它。4、
19、引导XenLinux的GRUB配置;一旦我们在Linux操作系统安装好Xen后,这样的系统应该被称为XenLinux。如何才能引导拥有Xen的Linux呢?这时我们要用到GRUB系统引导管理器。我们修改一下GRUB的配置文件menu.lst或grub.conf就行了。此文件位于/boot/grub目录中;4.1判断系统所在的分区;rootlocalhost # df -hFilesystem容量已用可用已用%挂载点/dev/hda6 12G 6.9G 4.9G 59% /4.2查看/boot目录中xen相关的配置文件;rootlocalhost # ls /boot注意:我们前面已经说过了,x
20、en提供了两个内核,一个是虚拟平台用的,也就是文件名带有xen0字样的;另一个带有xenU字样的,这是用于引导和支持虚拟操作系统用的。什么虚拟平台,比如我们想用Slackware的Xen虚拟Fedora、Gentoo . 。那么Slackware就是虚拟平台,而Fedora、Gentoo. .是被虚拟的操作系统。Slackware是一个真实安装在您的机器上的操作系统,它提供的是一个运行xen的环境。为了让Slackware能支持xen ,所以必须用于支持Xen的内核,也就是在/boot中有xen0字样的文件。如果您安装了Xen,会在/boot中有两个文件vmlinuz-2.6.12.6-xen
21、0和vmlinuz-2.6.12.6-xenU,4.3禁掉TLS Libraries ;rootlocalhost #mv /lib/tls /lib/tls.disabled禁掉的理由,请查看: Xen v3.0用户手册4.4引导XenLinux的GRUB内容;title SlackXenkernel /boot/xen-3.0.gzmodule /boot/vmlinuz-2.6-xen0 root=/dev/hda6 ro console=tty0如果有inintrd-2.xxxx-xen.img或initrd.gz之类的文件才能引导起来系统,还要加一行;要以/boot中的initrd相
22、关的文件为准;modules /boot/initrd.gz有关GRUB的文档:系统引导管理器GRUB,为初学者指南注意:与传统GRUB的定义有点不同,就是kernel是用来定义Xen的,而Linux的内核及initrd映像是通过module指令定义的;要仔细看好;5、Xen的配置和管理工具;5.1 Xen的相关文件存放位置;xen安装后,文件放在什么地方了呢?主要放在以下几个目录;5.11内核及xen自身存放于/boot安装有xen的操作系统下的/boot目录中,存放xen本身及支持xen的内核文件。比如文件名带有xen0和xenU相关的文件;5.12内核模块存放于/lib/modules内
23、核模块包括虚拟平台支持xen的内核xen0的模块,及支持虚拟操作系统所用的xenU的模块,一般的情况下是在/lib/modules下有两个xen相关的目录存放。一个是文件夹名带有xen0字样的,另一个是xenU字样的;5.13 xen的配置文件及守护程序的存放位置;一般的情况下,Xen的配置文件存放于/etc/xen目录。比如xend-config.sxp是用于配置网络的,不过我们不必更改,用其默认的就能完成我们的需要。xmexample1 xmexample2是两个示例性的配置文件。我们在配置引导被虚拟的操作系统时,这两个文件可供参考;Xen的服务器xend和xendomains启动脚本,一
24、般是位于/etc/init.d/目录中,也就是/etc/init.d/xend ;/etc/init.d/xend负责启动xend服务器,而/etc/init.d/xendomains负责第一个虚拟的系统及其它的Domains,也就是Domain 0 。5.14可执行命令存放于/usr/sbinrootlocalhost #ls /usr/sbin/xen*/usr/sbin/xen-bugtool /usr/sbin/xenconsoled /usr/sbin/xenmon.py /usr/sbin/xenstored/usr/sbin/xenbaked /usr/sbin/xend /us
25、r/sbin/xenperf /usr/sbin/xentoprootlocalhost #ls /usr/sbin/xm5.2 Xen服务器的启动;xend服务器的启动/停止/重启/状态查询,请用下面的命令;rootlocalhost # /etc/init.d/xend start启动xend,如果xend没有运行)rootlocalhost # /etc/init.d/xend stop停止xend,如果xend正在运行)rootlocalhost # /etc/init.d/xend restart重启正在运行的xend,如果xend没有运行,则启动rootlocalhost # /e
26、tc/init.d/xend status查看xend状态启动xendomains服务器的启动/停止/重启/状态查询,请用下面的命令;一般的情况下,xend服务器启动了,xendomains也会自动启动。所以这个只是掌握一下就行了;rootlocalhost # /etc/init.d/xend start启动xend,如果xend没有运行)rootlocalhost # /etc/init.d/xend stop停止xend,如果xend正在运行)rootlocalhost # /etc/init.d/xend restart重启正在运行的xend,如果xend没有运行,则启动rootloc
27、alhost # /etc/init.d/xend status查看xend状态rootlocalhost # /etc/init.d/xendomains startrootlocalhost # /etc/init.d/xendomains stoprootlocalhost # /etc/init.d/xendomains restartrootlocalhost # /etc/init.d/xendomains status5.3 Xen管理工具xm;我们前面提到Xen的可执行命令中,我们可能看到了一些以xen开头的命令,您不妨尝试一个一个的尝试一下他们是做什么用的;比如xend是服务
28、器的开启运行命令. .其中xm命令,就是管理Xen的最基本的工具;您可以通过xm -help来获得帮助;5.31列出所有正在运行的虚拟操作系统;rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 450 1 r- 5377.0fc5 4 256 1 -b- 0.1列出所有正在运行的虚拟系统(也可以称为虚拟机);我们可以看到,一个名为Domain-0的系统正在运行。Domain-0就是Xen本身,也可以称为虚拟平台内存大小,而Domain-0负责提供其它虚拟操作系统的硬件环境,其它的系统都
29、是基于Domain-0开始的,我们看到他的ID为0就应该知道它的权限是至高无尚的。所占用的内存是450M,不过这个是可以指定的。虚拟的CPU个数是1个,运行状态处于r,也就是run,正在运行中;运行时间是5377秒;还有一个虚拟系统fc5,他的id是4,占用内存256M,虚拟CPU个数是1个. .5.32通过配置文件来引导被虚拟的操作系统;rootlocalhost # /usr/sbin/xm create -c虚拟操作系统的启动配置文件比如我们要启动被虚拟的操作系统Fedora Core 5.0 ,我们要写一个启动Fedora的配置文件,比如是fc5vm.cfg。然后就可以通过下面的命令来
30、引导Fedora了;rootlocalhost # /usr/sbin/xm create -c fc5vm.cfg5.33从终端或控制台登录正在运行的虚拟操作系统;rootlocalhost # /usr/sbin/xm console正在运行的虚拟操作系统的Name或ID;举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 512 1 r- 5561.9fc5 4 256 1 -b- 0.2rootlocalhost # /usr/sbin/xm console fc55.34
31、存储正在运行的虚拟操作系统的状态及唤醒虚拟操作系统;rootlocalhost # /usr/sbin/xm saverootlocalhost # /usr/sbin/xm restore举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 458 1 r- 260.3fc5 2 256 1 - 6.5rootlocalhost # /usr/sbin/xm save 2 fc5run.saverootlocalhost # /usr/sbin/xm restore fc5run.
32、saverootlocalhost # /usr/sbin/xm console fc55.35停止正在运行的虚拟操作系统/激活停止的虚拟操作系统rootlocalhost # /usr/sbin/xm pauserootlocalhost # /usr/sbin/xm unpause举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 458 1 r- 260.3fc5 2 256 1 - 6.5rootlocalhost # /usr/sbin/xm pause 2rootloc
33、alhost # /usr/sbin/xm unpause 25.36调整虚拟平台/虚拟操作系统的占用内存我们可以调整正在运行中的虚拟平台(Domain-0)所占内存大小及虚拟操作系统所占用的内存大小;rootlocalhost # /usr/sbin/xm mem-set举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 458 1 r- 260.3fc5 2 256 1 - 6.5rootlocalhost # /usr/sbin/xm mem-set 2 1285.37关闭被
34、虚拟的系统rootlocalhost # /usr/sbin/xm shutdown虚拟操作系统的Name或DomIDrootlocalhost # /usr/sbin/xm destroy立即停止虚拟的系统(重要);举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 458 1 r- 260.3fc5 2 256 1 - 6.5rootlocalhost # /usr/sbin/xm shutdown fc5或rootlocalhost # /usr/sbin/xm shutdo
35、wn 2或rootlocalhost # /usr/sbin/xm destroy 25.38调整虚拟平台及虚拟操作系统的虚拟CPU个数;rootlocalhost # /usr/sbin/xm vcpu-set举例:rootlocalhost # /usr/sbin/xm listName ID Mem(MiB) VCPUs State Time(s)Domain-0 0 458 1 r- 260.3fc5 2 256 1 - 6.5rootlocalhost # /usr/sbin/xm vcpu-set 2 45.39查看虚拟系统运行的状态;rootlocalhost # xm top或
36、rootlocalhost # xentop6、虚拟操作系统的文件存储系统;我们虚拟的系统应该有一个存储的地方,也就是文件系统。被虚拟的系统能安装和运行在哪些文件系统上呢?能安装和运行在一个实际的物理分区上,一个映像文件中,或NFS等网络文件系统中;6.1以实际物理硬盘做为虚拟操作系统文件系统;以实际物理硬盘分区做为虚拟操作系统的文件系统,要经过硬盘分区,创建文件系统流程;请参考:Linux创建文件系统及挂载文件系统流程详解6.11准备物理分区及创建文件系统;Linux查看磁盘分区、文件系统、使用情况的命令和相关工具介绍实例解说fdisk使用方法合理规划您的硬盘分区Linux创建文件系统及挂载
37、文件系统流程详解6.12在物理分区上构建操作系统;构建操作系统,目前在一个Linux操作系统中构建另一个操作系统,主要是通过chroot工具和软件包提取工具来构建。基础的东西还是需要一点的,请参考:通过chroot构建Linux操作系统概要目前在开源社区中,已经有人把一些常用的发行版的基础系统做好了。我们能拿过来直接用。呵。只要有基础系统,我们就能chroot进入,我们就能用相应发行版软件包管理器来构建操作系统了。操作系统之基础系统资源:http:/jailtime.org您可以直接下载您喜欢的操作系统,解压后,然后挂载映像文件,然后把映像文件的内容都拷到物理分区中就好了。不过还得做一点小小的
38、修改,比如您下载系统映像文件中的/etc/fstab等文件。要根据您的引导的虚拟操作系统中定义的虚拟映射点来改。6.13虚拟操作系统的引导文件中关于文件系统的定义;如果您的硬盘有一定的空间,就可以把被虚拟的操作系统安装在硬盘的实际物理分区中,当然您首先得准备一个硬盘分区。然后格式化成Linux的文件系统,比如ext3或reiserfs等;然后是在这个分区上构建您想要虚拟的操作系统,最后才是写虚拟操作系统的引导配置文件,在配置文件中,要用phy:来指定。比如:disk = phy:hda7,sda1,w中文意思就是:disk=phy:分区,映射点,w这行是什么意思呢?就是表示被虚拟的操作系统安装
39、在/dev/hda3,我们要把hda3硬盘分区虚拟映射到/dev/sda1,并且是可读可写的;在这里要值得注意的是虚拟平台正在使用中的分区不能做为是映射点。比如我在Slackware是位于/dev/hda6的虚拟平台,也就是真实运行的操作系统,我想用它来虚拟位于/dev/hda7分区的Fedora。所以我不能把/dev/hda6做为hda7的映射点。也就是下面一行是错误的:disk = phy:hda7,hda6,w如何定义映射点,其实也比较好办,只要符合Linux设备的规则就可以;比如下面的也可以;disk = phy:hda7,sda2,wdisk = phy:hda7,sda3,wdis
40、k = phy:hda7,sdb1,wdisk = phy:hda7,sdb2,w. .什么是映射点呢?也就是说通过phy定义后,被虚拟的操作系统的位于的真实的物理分区,在虚拟平台中,被映射到另一个分区;可能这样说有点不太明白。呵。举个例子吧:比如我们在Slackware虚拟Fedora ,而Fedora位于/dev/hda7中。我们在引导Fedora的配置文件中定义Fedora所用的物理分区被映射到/dev/sda1;disk = phy:hda7,sda1,wroot = /dev/sda1 ro当我们把Fedora引导起来的时候,Fedora的文件系统就是用被虚拟后的分区,也就是/dev
41、/sda1。在Fedora中,我们通过df -h查看到Fedora是位于/dev/sda1。所以在引导Fedora的配置文件中,还要有一行来指定Fedora的root在哪里,就在/dev/sda1上;因为/dev/hda7已经被虚拟到了/dev/sda1。这回明白了吧;6.2以映像文件做虚拟操作系统的文件系统;以映像文件做为虚拟操作系统的文件系统,这种方法是比较常用。也是比较方便和易于操作的,也就是说被虚拟的操作系统是放在了一个文件中。6.21创建映像文件;rootlocalhost # dd if=/dev/zero of=fedora50.img bs=2k seek=2048k coun
42、t=1读入了1+0个块输出了1+0个块rootlocalhost # ls -lh fedora50.img-rw-r-r- 1 root root 4.1G 2006-04-13 01:27 fedora50.img我们可以用dd来创建映像文件,上面的例子是创建了大小为4.1G的体积的,名为fedora50.img的映像文件;您可以调整上面命令参数的大小来创建您想要的体积大小的映像文件。6.22格式化映像为Linux文件系统;Linux文件系统,比如ext3或reiserfs,看自己喜欢吧;您可以用mkfs.ext3或mkfs.reiserfs命令来创建文件系统,请参考:rootlocalh
43、ost # /sbin/mkfs.ext3 fedora50,imgmke2fs 1.38 (30-Jun-2005)fedora50,img is not a block special device.Proceed anyway? (y,n) y 注:在这里输入y就时行格式化了,然后遇到提示之处,都是用回车。这样fedora50.img就是ext3文件系统了,你可以用mount -o loop来挂载使用它,在它上面存储文件等。rootlocalhost # mkdir /mnt/fedora50rootlocalhost # mount -o loop fedora50.img /mnt/
44、fedora50rootlocalhost # df -hrootlocalhost:/opt# df -lhFilesystem容量已用可用已用%挂载点/dev/hda6 12G 8.5G 3.3G 73% /root/fedora50,img 4.0G 129M 3.7G 4% /mnt/fedora上面的一系列命令执行下去后,说明fedora50.img已经挂载到了/mnt/fedora目录中,我们可以向/mnt/fedora中存放文件。这样就写到了fedora50.img映像文件中。写完后,我们可以卸载fedora50.img;rootlocalhost # umount /mnt/fedora6.23