内容简介:Cobbler作为一个预备工具,使批量部署Red Hat/Centos/Fedora系统更容易,同时也支持Suse和Debian系统的部署。网上有许多cobbler 安装教程,但对于用shell脚本自动安装cobbler 的教程几乎没有,于是我花了一些时间写出了这个脚本,方便自己及他人安装系统使用!PS:本人比较懒,一般能用脚本自动化安装的服务,就不想一步步敲命令!不知道有没有和我想法一样的朋友?
前言:
Cobbler作为一个预备工具,使批量部署Red Hat/Centos/Fedora系统更容易,同时也支持Suse和Debian系统的部署。网上有许多cobbler 安装教程,但对于用 shell 脚本自动安装cobbler 的教程几乎没有,于是我花了一些时间写出了这个脚本,方便自己及他人安装系统使用!
PS:本人比较懒,一般能用脚本自动化安装的服务,就不想一步步敲命令!不知道有没有和我想法一样的朋友?
脚本环境
1.linux centos 7 系统
2.系统可连接外网
3.网络模式:NAT模式
实验步骤
1.上传cobbler 和slow 脚本到 Linux 系统/root目录下
方法一:挂载 方法二:通过Xftp软件上传
2.脚本cobbler.sh详解
#!/bin/bash #获取本机ip地址 ip=`ifconfig ens33 | grep "netmask" | awk '{print $2}'` #获取本机网段 net=`ifconfig ens33 | grep "netmask" | awk '{print $2}' | cut -c 1-10`
知识点:
1.获取本机IP办法是:先过滤出含有IP地址的行,再用awk过滤出含有IP的列
2.获取网段的方法是在获取IP后,用cut命令命令截取网段部分
3.cut -c 1-10 表示截取前10位字符
安装epel源
install_epel()
{
echo -e "\033[36m Installing epel... \033[0m"
if [ `yum --disablerepo=* --enablerepo=epel repolist | grep -c epel` -eq 0 ]
then
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
echo -e "\033[32m install epel finish! \033[0m"
else
echo -e "\033[32m epel already exists \033[0m"
fi
}
安装cobbler所有相关包
install_cobbler_softs() { echo -e "\033[36m Installing cobbler-softs... \033[0m" yum install cobbler cobbler-web dhcp tftp-server pykickstart httpd rsync xinetd tree -y if [ $? -ne 0 ] then echo -e "\033[31m install failed. \033[0m" exit 0 fi echo -e "\033[32m cobbler-softs finish! \033[0m" }
关闭防火墙,安全性
firewall() { systemctl stop firewalld setenforce 0 }
cobbler配置
configure_cobbler() { if [ $? -eq 0 ];then pass=`openssl passwd -1 -salt 'abc123' 'abc123' ` sed -i '102d' /etc/cobbler/settings sed -i "101idefault_password_crypted: \"$pass\"" /etc/cobbler/settings sed -i "s/^server: 127.0.0.1/server: $ip/g" /etc/cobbler/settings sed -i "s/^next_server: 127.0.0.1/next_server: $ip/" /etc/cobbler/settings sed -i 's/manage_dhcp: 0/manage_dhcp: 1/' /etc/cobbler/settings fi }
知识点:
1.添加密码方法是先插入新内容,再删除旧内容。
2.sed -i '102d' 是删除102行,sed -i "101i。。。" 在101行插入内容,需要注意的是,sed -i 后面加双引号才可插入变量$pass中的内容,单引号无法实现
- sed -i 's/manage_dhcp: 0/manage_dhcp: 1/' /etc/cobbler/settings 表示manage_dhcp: 1 替换 manage_dhcp: 0 ,不要弄反了!
dhcp模板配置
configure_dhcp_template() { if [ $? -eq 0 ];then sed -i "21s/192.168.1/$net/g" /etc/cobbler/dhcp.template sed -i "22s/192.168.1.5/$net.1/g" /etc/cobbler/dhcp.template sed -i "23s/192.168.1.1/$net.2/g" /etc/cobbler/dhcp.template sed -i "25s/192.168.1.100 192.168.1.254/$net.100 $net.200/" /etc/cobbler/dhcp.template fi }
知识点:
1.sed -i 后面要加双引号,不要用单引号,否则无法插入变量值!
2.最后一行是分配IP的地址池,这里是100-200,可根据实际情况修改!
tftpd配置
configure_tftpd() { echo -e "\033[36m Configure tftpd \033[0m" sed -i '14s/yes/no/' /etc/xinetd.d/tftp systemctl start xinetd }
重启所有服务
restart_services() { echo -e "\033[36m Restart cobbler's services \033[0m" systemctl restart cobblerd systemctl restart httpd systemctl restart cobblerd systemctl restart xinetd systemctl enable rsyncd }
函数汇总
main() { install_epel&& install_cobbler_softs && firewall && configure_cobbler &&configure_tftpd &&configure_dhcp_template &&restart_services &&./slow.sh }
知识点:
1.这里所有函数之间采用&&符号链接,表示上一条命令执行完成才会执行下一条
2.加&& 符号是必要的,否则软件包没下载完就配置了,必然出错,经过多次验证,不加&&,出错率很高!
执行所有函数
main
3.脚本slow.sh详解
#!/bin/bash
安装镜像,系统引导文件,同步
soft() { cob=`systemctl status cobblerd | grep "active (running)" | wc -l ` http=`netstat -ntap | grep :80 | wc -l` if [ $http -ne 0 ]&& [ $cob -eq 1 ]; then cobbler sync && systemctl restart dhcpd && mount /dev/sr0 /mnt && cobbler import --path=/mnt/ --name=CentOS-7-x86_64 --arch=x86_64 && cobbler get-loaders && systemctl start rsyncd else echo "httpd,cobbler no start!" fi }
知识点:
1.要先判断http和cobbler服务是否开启,否则cobbler sync同步一定会报错。
2.导入镜像文件会花费一点时间,这是正常状态,并非故障。
3.只有同步后(cobbler sync)才能开启dhcp服务,否则会报错。
检查所有服务状态
check_service() {
检查httpd服务状态
http=`netstat -ntap | grep :80 | wc -l` if [ $http -ne 0 ];then echo -e "\033\t[32m http is ok! \033[0m" else echo -e "\033\t[31m http error,check ! \033[0m" fi
检查cobbler 服务状态
cob=`systemctl status cobblerd | grep "active (running)" | wc -l ` if [ $cob -eq 1 ];then echo -e "\033\t[32m cobbler is ok! \033[0m" else echo -e "\033\t[31m cobbler error,check ! \033[0m" fi
检查iso镜像导入状态
os=`cobbler distro list | wc -l ` if [ $os -eq 1 ];then echo -e "\033\t[34m ISO file ok! \033[0m" else echo -e "\033\t[31m ISO file error,check ! \033[0m" fi
检查是否同步
sync=`cobbler sync |wc -l` if [ $sync -gt 1 ];then echo -e "\033\t[34m cobbler sync ok! \033[0m" else echo -e "\033\t[31m cobbler sync error,check ! \033[0m" fi
检查dhcp服务状态
dhcp=`systemctl status dhcpd | grep "active (running)" | wc -l ` if [ $dhcp -eq 1 ]; then echo -e "\033\t[32m dhcp is ok! \033[0m" else echo -e "\033\t[31m dhcp error,check ! \033[0m" fi
检查系统引导文件下载状态
load=\cobbler get-loaders | grep "already exists" | wc -l` if [ $load -gt 1 ];then echo -e "\033\t[34m get-loaders ok! \033[0m" else echo -e "\033\t[31m get-loaders error,check ! \033[0m" fi
检查tftp服务状态
tftp=`systemctl status xinetd | grep "active (running)" | wc -l` if [ $tftp -eq 1 ];then echo -e "\033\t[32m tftp is ok! \033[0m" else echo -e "\033\t[31m tftp error,check ! \033[0m" fi if [ $sync -gt 1 ];then echo -e "\033\t[34m cobbler sync ok! \033[0m" else echo -e "\033\t[31m cobbler sync error,check ! \033[0m" fi }
知识点:
由于涉及服务比较多,最后再逐一检查一下所有服务状态,以防出错!
函数汇总
main() { soft &✓_service }
执行函数
main
坑点及解决过程
1.可能有人会问,为什么要用2个脚本,很不方便啊 !原因如下:
在同一个脚本中使用 cobbler sync && systemctl restart dhcpd && mount /dev/sr0 /mnt && cobbler import --path=/mnt/ --name=CentOS-7-x86_64 --arch=x86_64 && cobbler get-loaders && systemctl start rsyncd 这些命令或其中的部分命令,都没执行,直接退出脚本!
解决办法:
我采取了判断,循环,等待等这些办法,都不能执行这些命令,甚至执行其实一条,都不行。 最后发现只有分开成2个脚本,才能顺利执行命令。
2.epel 源和 cobbler相关包一块下载会冲突
错误示例:rpm -ivh https://dl.fedoraproject.org/pub/epel/7/x86_64/Packages/e/epel-release-7-11.noarch.rpm &&yum makecache && yum install cobbler cobbler-web dhcp tftp-server pykickstart httpd rsync xinetd tree -y
解决办法:将命令分开在2个函数中,再通过判断查看执行状态(2个函数是install_epel 和install_cobbler_softs)。
总结:
1.此脚本花费了我一周多时间才完成,尽管如此,脚本还是有很多瑕疵,欢迎批评指出!
2.此脚本仅供参考,脚本方法不唯一。
3.不建议直接复制脚本内容使用,可去我的资料下载原脚本文件https://down.51cto.com/data/2461608
4.对cobbler自动装机过程不熟悉的,可先阅读我的博客https://blog.51cto.com/13760351/2151911
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深度探索Linux操作系统
王柏生 / 机械工业出版社 / 2013-10-15 / 89.00
《深度探索linux操作系统:系统构建和原理解析》是探索linux操作系统原理的里程碑之作,在众多的同类书中独树一帜。它颠覆和摒弃了传统的从阅读linux内核源代码着手学习linux操作系统原理的方式,而是基于实践,以从零开始构建一个完整的linux操作系统的过程为依托,指引读者在实践中去探索操作系统的本质。这种方式的妙处在于,让读者先从宏观上全面认清一个完整的操作系统中都包含哪些组件,各个组件的......一起来看看 《深度探索Linux操作系统》 这本书的介绍吧!