1、配置chrony服务,实现服务器时间自动同步
# 第一部分:配置chrony服务器
# 安装chront软件包
yum install -y chrony
# 编辑配置文件
cat > /etc/chrony.conf << EOF
server 1.centos.pool.ntp.org
server ntp.aliyun.com
server cn.pool.ntp.org
stratumweight 0
driftfile /var/lib/chrony/drift
rtcsync
makestep 1.0 3
allow 192.168.0.0/24
logdir /var/log/chrony
EOF
# 立即启动chrony服务并且设置为开机启动
systemctl start --now chronyd
# 校准时间
chronyc tracking
# 第二部分:配置chrony客户端
yum install -y chrony
# 192.168.0.12是刚才配置好的chrony
cat > /etc/chrony.conf << EOF
server 192.168.0.12
stratumweight 0
driftfile /var/lib/chrony/drift
rtcsync
logdir /var/log/chrony
EOF
systemctl start --now chronyd
chronyc tracking
2、实现cobbler+pxe自动化装机
# 实验条件
# 1、使用最小化安装方式进行安装而且没有进行配置的CentOS7系统
# 2、虚拟化软件为VMWare Workstation Pro 16
# 3、关闭VMWare软件NAT网络自带的DHCP服务
# 4、虚拟机开机前提前挂载好CentOS7系统的ISO镜像文件
# 5、本次实验选择大小超过4DB的ISO镜像文件,直接额外安装一些常用软件
# 6、所有命令均以root身份执行
# 7、用于测试自动化安装系统的虚拟机使用的内存不能低于2G
# 配置静态IP、DNS等网络参数实现正常联网
nmcli con add con-name static \
ifname ens33 autoconnect yes type ethernet \
ip4 192.168.0.13/24 gw4 192.168.0.2
nmcli con up static
echo 'nameserver 192.168.0.2' > /etc/resolv.conf
ip route add 192.168.0.0/24 via 192.168.0.2 dev ens33
systemctl restart NetworkManager
# 安装相关软件
yum install -y epel-release
yum install -y dhcp cobbler cobbler-web pykickstart xinetd
systemctl enable --now xinetd httpd dhcpd cobblerd tftp
# 修改Cobbler的配置文件
# 此处的192.168.0.13是刚才配置的本机IP
# “cobbler get-loaders”命令能否正常下载文件取决于实际的网络状况
# 如果不能正常下载相关文件,需要配置proxy_url,也就是代理服务器的ip地址和端口
# proxy_url是提供代理服务的主机地址,是为了让“cobbler get-loaders”命令正常下载文件
sed -i 's/^server: 127.0.0.1/server: 192.168.0.13/' /etc/cobbler/settings
sed -i 's/^next_server: 127.0.0.1/next_server: 192.168.0.13/' /etc/cobbler/settings
sed -i 's@^proxy_url_ext:.*@proxy_url_ext: "http://192.168.0.1:12333"@' /etc/cobbler/settings
sed -i 's@manage_dhcp: 0@manage_dhcp: 1@' /etc/cobbler/settings
# 下载必要的文件
cobbler get-loaders
# 设置xinetd服务接管tftp
cat > /etc/xinetd.d/tftp << EOF
service tftp
{
socket_type = dgram
protocol = udp
wait = yes
user = root
server = /usr/sbin/in.tftpd
server_args = -s /var/lib/tftpboot
disable = no
per_source = 11
cps = 100 2
flags = IPv4
}
EOF
systemctl enable rsyncd
systemctl restart cobblerd
# 此时执行“cobbler check”命令应该至少会看见两处需要配置的项目
# 这两个项目与Cobbler实现自动化安装系统无关,可以忽略
cobbler check
# 配置Cobble接管DHCP服务和相关的参数
sed -i.bak '21,25d' /etc/cobbler/dhcp.template
sed -i '20a \
subnet 192.168.0.0 netmask 255.255.255.0 { \
option routers 192.168.0.2; \
option domain-name-servers 192.168.0.2; \
option subnet-mask 255.255.255.0; \
range dynamic-bootp 192.168.0.50 192.168.0.200; \
' /etc/cobbler/dhcp.template
systemctl restart cobblerd.service
cobbler sync > /dev/null && echo OK
systemctl status dhcpd
# 导入ISO镜像文件
mount /dev/cdrom /mnt
cobbler import --path=/mnt --name=Centos-7.8 --arch=x86_64
cobbler list
# 编辑kickstart文件
cat > /var/lib/cobbler/kickstarts/Centos7.8-x86_64.cfg << EOF
auth --enableshadow --passalgo=sha512
# graphical
text
ignoredisk --only-use=sda
keyboard --vckeymap=us --xlayouts='us'
lang en_US.UTF-8 --addsupport=zh_CN.UTF-8
network --bootproto=dhcp --device=ens33 --ipv6=auto --activate
url --url="\$tree"
rootpw --iscrypted \$6\$PZQDlNOAE8CoR6dc\$DRTjMEghl6nB8W1m0hEjxGKHnWAvT3LOVFdYe2eC8atpAiFRpnC0hvT4Jleb31hXU1IezHMoMSo4RugErz8Ya0
selinux --disabled
firewall --disabled
firstboot --disable
services --disabled="chronyd"
reboot
timezone Asia/Shanghai --isUtc --nontp
user --groups=wheel --name=admin --password=\$6\$c.zcA6c8hLkmAy54\$uRnJPM9J/40FfbuyMwLhpjU.DF9bWpeG6TYD8K6ijLQECbLyBuEq12nsgNzfpJ3ai4xAJfk9PYUDUuNB8MfNR. --iscrypted --gecos="admin"
bootloader --location=mbr --boot-drive=sda
zerombr
clearpart --all --initlabel
part swap --fstype="swap" --ondisk=sda --size=2048
part /boot --fstype="ext4" --ondisk=sda --size=488
part / --fstype="xfs" --ondisk=sda --size=17943
%packages
@^minimal
@core
@"Development Tools"
vim-enhanced
lrzsz
net-tools
bash-completion
lsof
wget
%end
%addon com_redhat_kdump --disable --reserve-mb='auto'
%end
%anaconda
pwpolicy root --minlen=6 --minquality=1 --notstrict --nochanges --notempty
pwpolicy user --minlen=6 --minquality=1 --notstrict --nochanges --emptyok
pwpolicy luks --minlen=6 --minquality=1 --notstrict --nochanges --notempty
%end
EOF
# 导入ks文件
cobbler profile edit --name Centos-7.8-x86_64 --kickstart=/var/lib/cobbler/kickstarts/Centos7.8-x86_64.cfg
cobbler validateks
cobbler sync
在配置好Cobbler服务后,如果再进行变更配置参数比如修改kickstart文件,需要执行“cobbler sync”命令。
完成新建一个用于测试的虚拟机之后,必须手动将选项调整到“Centos-7.8-86_64”这一行。如下图所示: