Cobbler
Cobbler是一个开源项目,用来部署和安装系统。Cobbler不仅仅是一个pxe服务器,他还可以管理dns和dhcp。一般数据中心里或者生产环境,是不允许dhcp, 但是pxe需要使用dhcp,所以我们这里根据mac地址来分配IP,这样dhcp就不会影响现有网络了。
1. 首先关闭selinux
- sudo sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config
重新启动linux系统
2. 关闭防火墙iptables
- sudo chkconfig iptables off
- sudo chkconfig ip6tables off
- sudo /etc/init.d/iptables stop
- sudo /etc/init.d/ip6tables stop
3. 安装 epel 包
- sudo yum install http://mirrors.ustc.edu.cn/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm
4. 安装 Cobbler 和它需要的第三方工具包
- sudo yum install cobbler cobbler-web xinetd pykickstart cman dhcp tftp-server bind
安装完成后需要设置几个服务自动启动
- sudo chkconfig httpd on
- sudo chkconfig dhcpd on
- sudo chkconfig cobblerd on
- sudo service httpd start
- sudo service cobblerd start
注:此时dhcpd应该启动失败,因为还没有对dhcp做配置。
5. 配置
5.1 修改/etc/xinetd.d/tftp
- disable = yes
- =>
- disable = no
5.2 修改/etc/xinetd.d/rsync
- disable = yes
- =>
- disable = no
5.3 编辑 /etc/cobbler/settings 文件,设置以下各项,其中 192.168.145.102 是当前机器IP。
- server: 192.168.145.102
- next_server: 192.168.145.102
- pxe_just_once: 1
- manage_rsync: 1
- manage_dhcp: 1
5.4 设置默认 root 用户的秘密
- $ sudo openssl passwd -1 -salt 'random-phrase-here' 'Letmein'
然后将结果替换 /etc/cobbler/settings 文件中的
default_password_crypted:
5.5 设置 Cobbler Web访问的密码
- sudo htdigest /etc/cobbler/users.digest "Cobbler" cobbler
5.6 编辑 /etc/cobbler/dhcp.template 文件,下面是我改动部分的配置信息
- ...
- subnet 192.168.145.0 netmask 255.255.255.0 {
- option routers 192.168.145.102;
- option domain-name-servers 192.168.145.1;
- option subnet-mask 255.255.255.0;
- #range dynamic-bootp 192.168.145.150 192.168.145.200;
- default-lease-time 21600;
- max-lease-time 43200;
- next-server $next_server;
- filename "/pxelinux.0";
- host test { # 为指定机器指定ip地址
- hardware ethernet 08:00:27:2C:30:8C;
- fixed-address 192.168.145.155;
- }
- }
- ...
注意:如果在现有网段内已经有DHCP服务器,需要把 range dynamic-bootp 注释掉,否则会有冲突。这个地方需要特别注意,要根据自己的网络情况来设置。
5.7 重启服务
- sudo service xinetd restart
- sudo service httpd restart
- sudo service cobblerd restart
5.8 启动和检测 cobbler
- sudo cobbler get-loaders
- sudo cobbler check
此时如果有错误,cobbler会提示,可以根据提示来修复。但是对参数的任何修改都需要使用下面的命令来使其生效
- sudo cobbler sync
5.9 Web 测试
- 访问 http://192.168.145.102/cobbler_web
- 用户名/密码:cobbler/Letmein
6. 导入系统镜像
这里假定使用CentOS-6.6-x86_64来测试
- sudo mount -t auto -o loop /home/kongxx/share/os/CentOS-6.6-x86_64-bin-DVD1.iso /mnt
- sudo cobbler import --path=/mnt --name=CentOS-6.6 --arch=x86_64
运行这两条命令后,可以使用下面的命令来查看了
- $ sudo cobbler distro list
- $ sudo cobbler profile list
也可以通过 Web 界面的 Distros 和 Profiles 来查看。
7. 自动安装系统
由于是在家里的虚拟机里做测试,所以没法使用 IPMI 来管理物理机。这里就只测试一下新的虚拟机可以通过PXE来自动安装系统。
使用VirtualBox创建一个虚拟机,网络设置使用和上面同样的桥接模式。但是在 "虚拟机设置-> 系统 -> 启动顺序" 里把网络勾上并上移到第一位,然后启动虚拟机。此时就可以进入 Cobbler 的网络安装界面,选择上面创建的 CentOS-6.6-x86_64 然后就可以自动安装了。装完后,记得把虚拟机启动顺序改回到硬盘启动优先,然后就可以启动新安装的虚拟机了。