002.kickstart部署之nfs架构(代码片段)

itzgr itzgr     2023-02-16     256

关键词:

一 准备

1.1 完整架构:Kickstart+DHCP+NFS+TFTP+PXE

1.2 组件应用

Kickstart服务端IP:172.24.8.12
DHCP:提供客户端IP,网关,镜像路径等;
TFTP:共享pxelinux.0、initrd.img、vmlinux、isolinux.cfg、boot.msg、vesamenu.c32、splash.png文件
NFS:共享ks.cfg、及所有光盘文件

注意:此ks.cfg文件和所有光盘文件也可通过HTTP、FTP等方式共享,参考其他笔记即可。

1.3 TFTP等组件安装

[[email protected] ~]# yum -y install dhcp* tftp* rpcbind nfs-utils
[[email protected] ~]# yum -y install xinetd		#tftp依赖于xinetd,因此需要安装xinetd

1.4 挂载系统光盘

[[email protected] ~]# mount /dev/sr0 /mnt/cdrom/

1.5 关闭防火墙及SELinux

[[email protected] ~]# systemctl stop firewalld.service
[[email protected] ~]# systemctl disable firewalld.service
[[email protected] ~]# setenforce 0
[[email protected] ~]# vi /etc/selinux/config				#彻底关闭SELinux
SELINUX=disabled

二 服务端的配置

2.1 配置DHCP

[[email protected] ~]# vi /etc/dhcp/dhcpd.conf
option domain-name-servers 223.5.5.5,223.6.6.6; 	#全局DNS
default-lease-time 600;					#默认的租赁时间
max-lease-time 7200;					#最大可租赁时间
subnet 172.24.8.0 netmask 255.255.255.0 		#设置网段
range 172.24.8.13 172.24.8.50;				#设置可分配地址池
option routers 172.24.8.2;				#默认网关
next-server 172.24.8.12; 				#tftp server的ip
filename "pxelinux.0";					#pxe boot需要的启动文件名, 相当于bootloader
[[email protected] ~]# systemctl start dhcpd.service		#启动dhcp服务
[[email protected] ~]# systemctl enable dhcpd.service		#开机自动启动

2.2 NFS配置

[[email protected] ~]# mkdir /centosinstall				#创建nfs共享目录
[[email protected] ~]# chown nfsnobody:nfsnobody /centosinstall/	#修改目录所有者
[[email protected] ~]# vi /etc/exports
 /centosinstall 172.24.8.0/24(rw,sync)
[[email protected] ~]# cp /mnt/cdrom/* /centosinstall/		#将光盘下所有文件拷贝到nfs目录下
[[email protected] ~]# systemctl start rpcbind.service
[[email protected] ~]# systemctl enable rpcbind.service
[[email protected] ~]# systemctl start nfs-server.service
[[email protected] ~]# systemctl enable nfs-server.service

2.3 配置TFTP

[[email protected] ~]# vi /etc/xinetd.d/tftp
service tftp

   ……
    server		= /usr/sbin/in.tftpd
    server_args	= -s /var/lib/tftpboot				#此为TFTP服务根目录
    disable		= no                              	#打开TFTP
    ……

[[email protected] ~]# systemctl start xinetd.service			#启动xinetd,则xinetd管理的tftp也会启动
[[email protected] ~]# systemctl enable xinetd.service		#开机启动xinetd,则xinetd管理的tftp也会启动

2.4 TFTP文件配置

#在TFTP目录中指定相关PXE内核模块及相关参数
[[email protected] ~]# yum -y install syslinux			#Linux引导加载程序
[[email protected] ~]# find / -name pxelinux.0
/usr/share/syslinux/pxelinux.0					#查找pxelinux.0文件所在目录
[[email protected] ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
#将pxelinux.0复制到TFTP所在目录,以便客户端(需要自动安装系统的主机)通过TFTP能找到此加载程序。
[[email protected] ~]# cp /mnt/cdrom/images/pxeboot/initrd.img,vmlinuz /var/lib/tftpboot/
#copy光盘目录中的vmlinuz和initrd.img, 这两个文件相当于系统启动时/boot目录下的启动文件
[[email protected] ~]# mkdir -p /var/lib/tftpboot/pxelinux.cfg
[[email protected] ~]# cp /mnt/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
#TFTP目录下新建pxelinux.cfg的目录,将【isolinux.cfg:启动时显示配置文件信息】复制到此目录下。
[[email protected] ~]# cp /mnt/cdrom/isolinux/boot.msg,splash.png /var/lib/tftpboot/
#copy pxe引导所需要的配置文件, splash.png:背景图. boot.msg启动标语, vesamenu.c32: 显示同行界面用的程序.

2.5 ks.cfg文件的修改

注意:此文件为安装过程中自动应答文件,可将Kickstart的anaconda-ks.cfg文件为模板,也可采用图形化方式设置此文件【参考006笔记】。
[[email protected] ~]# cp /root/anaconda-ks.cfg /centosinstall/ks.cfg
[[email protected] /]# chmod 755 /centosinstall/ks.cfg
[[email protected] ~]# vi /centosinstall/ks.cfg
auth --enableshadow --passalgo=sha512
nfs --server=172.24.8.12 --dir=/centosinstall
graphical
firstboot --enable
ignoredisk --only-use=sda
keyboard --vckeymap=us --xlayouts=‘us‘
lang en_US.UTF-8 --addsupport=zh_CN.UTF-8			#根据需求增加语言支持
reboot
network  --bootproto=dhcp --device=eno16777736 --onboot=yes --ipv6=auto --activate
#此项采用默认即可,测试修改网卡名为eth0也无法生效,依旧是eno16777736。
network  --hostname=localhost.localdomain
rootpw --iscrypted $6$LgafQJ7F1rcyRCpk$ZteQKXvywjifMoPbAnhm7nESFx4fuROoxVYie4YvP04DGiUGpjEW2mA.m0TUQyq1ZoOUv.EF9vMWUaBjGyowW.
services --disabled="chronyd"
timezone Asia/Shanghai --isUtc --nontp
bootloader --append=" crashkernel=auto" --location=mbr --boot-drive=sda
clearpart --all --initlabel
part /boot --fstype="xfs" --ondisk=sda --size=300
part pv.195 --fstype="lvmpv" --ondisk=sda --size=30419
volgroup centos --pesize=4096 pv.195
logvol /  --fstype="xfs" --size=1 --name=root --vgname=centos --grow
logvol swap  --fstype="swap" --size=2148 --name=swap --vgname=centos
logvol /home  --fstype="xfs" --size=10340 --name=home --vgname=centos
%packages
@^minimal
@core
kexec-tools
%end
%addon com_redhat_kdump --enable --reserve-mb=‘auto‘
%end
注意:
1:key --skip:为红帽系统跳过输入序列号过程;若为CentOS 系列,则可以不保留此项内容;
2:reboot: 必须项,也必须文中设定位置,不然安装完后无法自动重启;
3:clearpart --all --initlabel:必须项,自动选择清除所有数据,无需人为干预。
[[email protected] ~]# systemctl restart xinetd			#重启tftp服务

2.6 Kickstart配置

[[email protected] ~]# chmod 755 /var/lib/tftpboot/pxelinux.cfg/default
#将此文件赋予修改权限,默认不可修改。
[[email protected] ~]# vi /var/lib/tftpboot/pxelinux.cfg/default
default linux							#默认采用的启动项
timeout 1							#等待时间
label linux
  menu label ^Install CentOS 7
  kernel vmlinuz
  append ks=nfs:172.24.8.12:/centosinstall/ks.cfg initrd=initrd.img quiet
[[email protected] ~]# systemctl restart xinetd			#重启tftp服务
#timeout 1:#选择停留时间为1秒
#172.24.8.12:Kickstart服务器;
#/centosinstall:nfs共享Linux镜像的目录,即Linux存放安装文件的路径;
#ks.cfg:Kickstart自动应答配置文件;
#不同服务共享ks写法——
HTTP Server ks=http://server_ip:port/path/kickstart_file
HTTPS Server ks=https://server_ip:port/path/kickstart_file
FTP Server ks=ftp://serverip:port/path/kickstart_file
NFS Server ks=nfs:server_ip:/path/kickstart_file

三 客户机测试

客户机开机自动安装
注意:客户机需要和服务端在同一网段,或能从服务端获取IP及相关文件。

云原生之kubernetes实战在k8s集群下部署wordpress(代码片段)

【云原生之kubernetes实战】在k8s集群下部署wordpress一、wordpress介绍1.wordpress简介2.wordpress的优点3.wordpress使用场景二、检查本地kubernetes集群状态三、配置nfs共享存储1.安装nfs2.创建共享目录3.配置共享目录4.使配置生效5.重启nfs相关服... 查看详情

nfs共享存储服务部署(代码片段)

第1章NFS介绍1.1NFS基本概述NFS(NetworkFileSystem)网络文件系统主要功能是通过局域网络让不同的主机系统之间可以共享文件或目录。NFS系统和Windows网络共享、网络驱动器类似,只不过windows用于局域网,NFS用于企业集群架构中,如果是... 查看详情

keepalived+lvs+tomcat+nfs架构部署(代码片段)

...168.59.10)相同配置(把上面再执行一遍)三、部署共享存储(NFS:192.168.59.14)安装nfs和rpcbind创建共享目录并设置权限输入页面内容 设置共享目录并发布共享备lvs:192.168.59.10相同配置四、部署节点服... 查看详情

lnmp架构之nginx的安装与部署(代码片段)

#############################systemctlstopfirewalld.servicesystemctldisablefirewalld.servicesetenforce0#############################yum-yinstallpcre-devel.x86_64zlib-devel.x86_64gccgcc-c++make 查看详情

lnmp架构之nginx的安装与部署(代码片段)

#############################systemctlstopfirewalld.servicesystemctldisablefirewalld.servicesetenforce0#############################yum-yinstallpcre-devel.x86_64zlib-devel.x86_64gccgcc-c++make 查看详情

inotify+rsync实现实时同步部署(代码片段)

1.1.架构规划1.1.1架构规划准备服务器系统角色IPCentos6.7x86_64NFS服务器端(NFS-server-inotify-tools)192.168.1.14Centos6.7x86_64rsync服务器端(rsync热备服务器)192.168.1.17   1.1.2架构图 2.1部署前检查2.1.1检查rsync热备服务器daemon是 查看详情

基于nfs实现lamp的负载均衡之四:部署mariadb

192.168.1.200上操作一、安装mariadb:yuminstall-ymariadb-serversystemctlstartmariadb      //启动服务  二、配置数据库:mysql      //登录mysqlSETPASSWORDFO 查看详情

基于nfs实现lamp的负载均衡之六:部署discuz论坛

一、创建用户,用于部署网站:在两台httpd服务器上操作useradd-r-u80httpdadmin      //创建httpd管理员 echo"12345"|passwd--stdinhttpdadmin       //配置密码 visudo 查看详情

云原生之kubernetes实战在kubernetes集群下部署rainbond平台

【云原生之kubernetes实战】在kubernetes集群下部署Rainbond平台一、Rainbond介绍1.Rainbond简介2.Rainbond特点二、检查本地kubernetes集群状态1.检查工作节点状态2.检查系统pod状态三、安装nfs共享存储1.安装nfs2.配置共享目录3.使配置生效4.设置... 查看详情

nfs(代码片段)

...常稳定;大型公司使用(mfs,glusterfs,fastdfs)nfs优点:部署和维护简单;数据是在文件系统之上,是能看见真实的数据,大型分布式文件系统都是看不到数据的;可靠稳定nfs缺点:存在单点故障;高并发NFS效率和性能有限;客户端认... 查看详情

nfs架构(代码片段)

title:NFS架构tags:nfs,rpc,rpcbindgrammar_cjkRuby:trueNFS架构1.NFS简述NFS(NetworkFileSystem)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在NFS的应用中,本地NFS的客户端应用可以透明... 查看详情

中小集群架构之集群共享nfs-server与备份backup-server

本文简单搭建NFS与Backup服务器=====================================================环境:CentOS6.8-x86_64 2.6.32-642.el6.x86_64 系统为最小化安装,也做了基础优化。NFS:IP192.168.0.81/24 eth0Backup:IP192.168.0.82/24&nbs 查看详情

mysql高可用架构之mha(理论+部署+故障模拟)(代码片段)

...、MHA工作原理及特点四、MHA搭建及故障模拟4.1搭建环境4.2部署思路4.3安装MySQL数据库与主从同步4.4配置MHA4.5manager和node安装后生成的常用脚本和工具4.6配置无密码认证4.7修改MHA相关配置4.8查看无密码认证和manager节点上m 查看详情

云原生之kubernetes实战在k8s集群下部署weavescope监控平台(代码片段)

【云原生之kubernetes实战】在k8s集群下部署WeaveScope监控平台一、WeaveScope介绍1.WeaveScope简介2.WeaveScope的特点3.WeaveScope的组成二、检查本地kubernetes集群状态1.检查工作节点状态2.检查系统pod状态三、安装nfs共享存储1.安装nfs2.创建共享... 查看详情

云原生之kubernetes实战在k8s下部署redis集群

【云原生之kubernetes实战】在k8s下部署Redis集群一、检查本地k8s集群环境1.检查工作节点状态2.检查系统pod状态二、安装helm工具1.下载helm二进制包2.解压压缩包3.复制文件4.查看helm版本5.helm命令补全三、部署NFS服务1.安装nfs2.创建共... 查看详情

云原生之kubernetes实战在k8s环境下部署spark分布式计算平台(代码片段)

【云原生之kubernetes实战】在k8s环境下部署Spark分布式计算平台一、Spark介绍1.Spark简介2.Spark作用二、检查本地集群状态1.检查工作节点状态2.检查k8s版本二、安装helm工具1.下载helm软件包2.解压压缩包3.复制二进制文件4.检查helm版本5.... 查看详情

基于nfs实现lamp的负载均衡之三:部署bind9

在192.168.1.101上操作一、安装bind9:yuminstall-ybind  二、配置bind9:cp/etc/named.conf{,.back}             //先做备份vim/etc/named.conf650)this 查看详情

nfs共享储存服务部署(代码片段)

...统一般被用来存储共享视频、图片等静态资源文件。环境部署:redhat6.5系统服务器Ip:192.168.100.101客户端ip:192.168.100.102NFS服务器部署:1.需 查看详情