您所在的位置:操作系统 > 运维经验&工具 > 用ezjail来创建和管理jail虚拟机(2)

用ezjail来创建和管理jail虚拟机(2)

2011-04-07 13:40 抚琴煮酒 51CTO 字号:T | T
一键收藏,随时查看,分享好友!

在公司的环境中,需要快速和大量的部署jail虚拟机,原先的make world的方式就显得非常力不从心,大家都知道,make world就算在双四核的机器上也是极慢的;查阅了freebsd的官方文档,它向我们推荐管理及创建jail的工具--ezjail。

AD:

我现在想通过ezjail为我的jail.cn7788.com,IP名为192.168.1.103的机器(相当于母机)安装一台名为apache.cn7788.com,IP为192.168.1.104及一台名为research.cn7788.com,IP为192.168.1.105的jail机器。

具体步骤如下:(权限要求很大,这里为了方便,我暂时切换到root下操作)

(1)编辑网卡地址,为网卡创建二个子网地址

vim /etc/rc.conf,添加代码如下:

ifconfig_em0_alias0="inet 192.168.1.104 netmask 255.255.255.0"
ifconfig_em0_alias1="inet 192.168.1.105 netmask 255.255.255.0"

重启后,通过ifconfig 观察下网卡的IP,截图如下:

通过ifconfig 观察下网卡的IP

(2)编译内核

由于是最小化安装,所以没有/usr/src目录,我们可以通过sysinstll工具来安装此目录。

sudo sysinstall -> Configure -> Distributions -> src -> ALL -> Install from a FreeBSD CD/DVD

然后是编译内核

cd /usr/src
make buildworld

此过程比较漫长,建议在下班时间或空闲时间做,无论是四核或八核的机器,做二小时的预算。

(3)ports安装ezjail工具

cd /usr/ports/sysutils/ezjail
make install clean

(4)生成jail模板

ezjail-admin update -p -i

-p:提供给jail ports

-i:不再运行make world,因为第一步我们已经做了。

(5)生成名为apache.cn7788.com和reseach.cn7788.com的子jail机器

ezjail-admin create -r /usr/jails/apache apache.cn7788.com 192.168.1.104
ezjail-admin create -r /usr/jails/research research.cn7788.com 192.168.1.105

该命令可以分别在/usr/jails/apache和/usr/jails/research目录下建立名为了apache.cn7788.com和research.cn7788.com的jail机器。

(6)让192.168.1.103的机器开机即启动ezjail工具

操作如下:

在/etc/rc.conf最后添加代码如下:

ezjail_enable="YES"

(7)分别通过ezjail启动这二个jail机器

/usr/local/etc/rc.d/ezjail.sh start apache.cn7788.com
/usr/local/etc/rc.d/ezjail.sh start research.cn7788.com

这里补充说明下:ezjail由两个脚本组成:ezjail-admin和ezjail.sh,前者用于创建、更新和删除Jail,后者用于启动、停止和重启Jail。

(8)通过ezjail-admin list查看jail机器的情况

[andrewy@jail ~0m]$ ezjail-admin list
STA JID IP Hostname Root Directory
----------------------------------------------------------------------------
DR 2 192.168.1.105 research.cn7788.com /usr/jails/research
DR 1 192.168.1.104 apache.cn7788.com /usr/jails/apache

(9)启动jail机器的ssh

启动sshd的方法跟平常一样的,没有任何区别。

先通过jexec 1或2 sh登入该jail,然后echo ' sshd_enable="YES" ' >> /etc/rc.conf,然后通过ezjail.sh命令重新启动虚拟机

jail# /usr/local/etc/rc.d/ezjail.sh restart apache.cn7788.com
Stopping jails: apache.cn7788.com.
Configuring jails:.
Starting jails: apache.cn7788.com.
jail# /usr/local/etc/rc.d/ezjail.sh restart research.cn7788.com
Stopping jails: research.cn7788.com.
Configuring jails:.
Starting jails: research.cn7788.com.

(10)如果要添加新jail机器,重复以上步骤即可。

(11)jail机器的备份是非常容易的

对相应的目录进行备份即可;其实我建议只对重要资料进行备份,jail机器crash了的话,重建一个也是非常快速的事情。

(12)建议用ezjail的方式创建和管理

如果大家有大规划部署虚拟机的需求的话,建议用ezjail的方式创建和管理,它创建的速度非常之快,而且子jail极小,如果遇到崩溃的情况的话,它恢复起来也极慢,现在我基本上在我每台jail机器上都部署了ezjail了。

【51CTO独家特稿,转载请标明出处及作者!】

【编辑推荐】

  1. FreeBSD 8.0下jail虚拟机完全实践
  2. FreeBSD 8.1下用nginx配置简单web负载均衡
  3. 最小化安装FreeBSD8服务器后建议做的事
【责任编辑:李晶 TEL:(010)68476606】



分享到:

  1. 简单好用的9个电脑必备工具!让你轻松10倍
  2. 教程:使用U盘将Linux Mint安装到Windows笔记本上

热点职位

更多>>

热点专题

更多>>

读书

Java程序设计教程
本书对第1版的某些章节作了合理的调整,增加了部分实用的程序,并在每一章的最后加了适量的练习题,以巩固前面所学的知识,更加有利

51CTO旗下网站

领先的IT技术网站 51CTO 中国首个CIO网站 CIOage 中国首家数字医疗网站 HC3i 51CTO学院