设为首页 加入收藏

TOP

Linux 系统自动化部署系统(一)
2023-07-23 13:29:41 】 浏览:58
Tags:Linux

linux安装光盘中的相关文件:

[root@Centos8 cdrom]# ls
BaseOS  EFI  images  isolinux  LICENSE  media.repo  Minimal  TRANS.TBL

#isolinux:存放和安装相关的文件
[root@Centos8 isolinux]# ls
boot.cat  boot.msg  grub.conf  initrd.img  isolinux.bin  isolinux.cfg  ldlinux.c32  libcom32.c32  libutil.c32  memtest  splash.png  TRANS.TBL  vesamenu.c32  vmlinuz

boot.cat: 相当于grub的第一阶段,加载MBR中的bootloader到内存

isolinux.bin:光盘引导程序

isolinux.cfg:启动菜单的配置文件(是一个文本文件,用于设置开机的光盘界面)

....c32:提供了启动菜单功能的文件

memtest:内存检测程序

splash.png:光盘启动菜单界面的背景图

vmlinuz:是内核映像文件

initrd.img:ramfs文件,是linux的一个精简系统,里面有文件系统的驱动
内核参数
isolinux/isolinux.cfg中设置相关的内核加载参数,实现不同的安装过程

#不同的启动模式,比如救援模式等,就是采用了不同的内核参数。

#指定内核参数的方法:
法一:在启动菜单界面,选中一项安装方法,按tab键,在后面增加参数

法二:在启动菜单界面,任意选中一项安装方法,按ESC键:boot: linux 参数设置 (linux表示isolinux.cfg中指定的一个标签)

#常见的内核参数:
text:指定文本方式的安装界面
rescue:进入救援模式
ks=path: 指定自动化安装应答文件路径,

#boot.iso:只是用来启动的镜像文件

自动安装的应答文件

应答文件,称为kickstart文件,用于保存安装过程需要指定的选项。

#kickstart文件主要包括三个部分:命令段,程序包段,脚本段
命令段:指明各种安装前配置,如键盘类型等

#命令段中的常见命令:
	keyboard: 设定键盘类型
	lang: 语言类型
	zerombr:清除mbr
	clearpart:清除分区
	part: 创建分区
	rootpw: 指明root的密码
	timezone: 时区
	text: 文本安装界面
	network:指定网络设置
	firewall:设置防火墙设置
	selinux:设置selinux设置
	reboot:安装完自动重启
	user:安装完成后为系统创建新用户
	url: 指明安装源

#程序包段:指明要安装的程序包组或程序包,不安装的程序包等
	%packages
	@^environment group: 指定环境包组,如:@^minimal-environment
	@group_name
	package
	-package
	%end

#脚本段:
	%pre: 安装前脚本
	%post: 安装后脚本

#注意:
CentOS 8,7,6 不同版本的kickstart文件格式不尽相同,不可混用
 %addon, %packages, %onerror, %pre 、 %post 必须以%end结束,否则安装失败

kickstart文件创建

  • 使用图形工具创建(centos7支持)

  • 使用自带的模板生成

可使用创建工具:system-config-kickstart ,注意:此方法 CentOS 8不再支持

依据某模板修改并生成新配置,CentOS安装完后,会自动参考当前系统的安装过程,生成一个kickstart文件 /root/anaconda-ks.cfg
检查ks文件的语法错误:
使用 ksvalidator 工具可以检查kickstart的文件格式是否有语法错误,来自于 pykickstart 包

格式:ksvalidator /PATH/TO/KICKSTART_FILE

DHCP服务的实现

  • DHCP:Dynamic Host Configuration Protocol,动态主机配置协议

  • DHCP使用的是UDP协议,服务端使用67/udp端口,客户端使用68/udp端口

  • DHCP主要实现的是局域网类自动给客户机分配ip地址、网段、dns等内容

DHCP工作过程:
  1. 客户机发送广播报文寻找DHCP服务器(DISCOVER广播报文)

  2. DHCP服务器回应客户机(OFFER报文)

  3. 客户机回应指定的DHCP服务器(REQUEST报文,先到先得的原则)

  4. DHCP和客户机签订协约(ACK报文)

DHCP的实现
注意:实现DHCP服务前,先将网络已有DHCP服务,如:vmware中的DHCP关闭,访止冲突
DHCP服务的实现软件:
  • dhcp(CentOS 7 之前版本) 或 dhcp-server(CentOS 8 中的包名) #功能更强大

  • dnsmasq:小型服务软件,可以提供dhcp和dns功能

DHCP相关文件的组成
dhcp或dhcp-server 包文件组成
[root@Centos8 ~]# rpm -ql dhcp-server
/etc/NetworkManager
/etc/NetworkManager/dispatcher.d
/etc/dhcp
/etc/dhcp/dhcpd.conf #dhcp服务配置文件
/etc/dhcp/dhcpd6.conf
/etc/openldap/schema 
/etc/openldap/schema/dhcp.schema
/etc/sysconfig/dhcpd
...
/usr/share/doc/dhcp-server/dhcpd.conf.example #dhcp服务配置范例文件
/usr/lib/systemd/system/dhcpd.service ##dhcp服务service文件
/usr/lib/systemd/system/dhcpd6.service
/usr/sbin/dhcpd  #dhcp服务主程序
/usr/share/doc/dhcp-server
/var/lib/dhcpd/dhcpd.leases 地址分配记录
...
/var/lib/dhcpd
...
dhcp-client客户端包
...
/usr/sbin/dhclient #客户端程序
/var/lib/dhclient #自动获取的IP信息
...
DHCP服务器配置文件
cp /usr/share/doc/dhcp-server/dhcpd.conf.example /etc/dhcp/dhcpd.conf #拷贝一个范例文件进行更改
#注意:
DHCP服务器本身采用静态IP

必须配置和DHCP网卡的静态IP所在网段的subnet段,否则DHCP服务无法启动(比如自己的ip是10网段,首先就要给10网段配置dhcp)

#全局配置
subnet {
 ...
 }
host {
}

next-server:提供引导文件的服务器IP地址

filename: 指明引导文件名称
范例
subnet 192.168.100.0 netmask 25
首页 上一页 1 2 3 下一页 尾页 1/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇基于容器部署一个web站点 下一篇Linux Shell 自动交互功能

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目