kickstart+http+dhcp+tftp实现centos7的无人值守安装

环境:
IP: 172.16.0.11 centos 7.2

一. tftp

安装tftp服务端和客户端
[root@localhost ~]# yum -y install tftp tftp-server
启动tftp
[root@localhost ~]# systemctl start tftp.socket
[root@localhost ~]# systemctl enable tftp.socket

[root@localhost ~]# ss -unl | grep :69
UNCONN     0      0           :::69                      :::*

在tftp工作目录下准备一个文件,进行测试
[root@localhost ~]# ls /var/lib/tftpboot/
[root@localhost ~]# cp /etc/grub2.cfg /var/lib/tftpboot/
先切换到本地/tmp目录, 因为tftp不支持lcd命令
[root@localhost ~]# cd /tmp
下载grub2.cfg文件
[root@localhost tmp]# tftp 172.16.0.11
tftp> get grub2.cfg
tftp> quit

查看本地目录: 
[root@localhost tmp]# ls
fstab  grub2.cfg  nginx.conf

删除测试文件
[root@localhost tmp]# rm /var/lib/tftpboot/grub2.cfg

二. dhcp

[root@localhost tmp]# cd /etc/dhcp
[root@localhost dhcp]# vim dhcpd.conf
注释掉host配置项
#host hostname {       #名称标识  和客户端hostname可以不同
# hardware ethernet 00:0c:29:f9:98:20;   #客户端mac
# fixed-address  172.16.100.10;          #给上面的mac固定ip地址
#}


option domain-name "magedu.com";    #搜索后缀
option routers 172.16.0.254;        #网关, 配置成实际的网关
option domain-name-servers 202.106.0.20;   #dns地址



subnet 172.16.0.0 netmask 255.255.0.0 {            #子网
    range 172.16.100.101 172.16.100.130;           #地址池
    filename "pxelinux.0";
    next-server 172.16.0.11;
}


[root@localhost dhcp]# systemctl restart dhcpd.service
[root@localhost dhcp]# ss -unl | grep :67
UNCONN     0      0            *:67                       *:*

三. yum 仓库

使用光盘做yum仓库, 最好拷贝到某个目录,而不是直接挂载光盘, 此处直接挂载
[root@localhost dhcp]# mkdir -pv /var/www/html/centos/7/x86_64
[root@localhost dhcp]# mount -r /dev/cdrom /var/www/html/centos/7/x86_64
[root@localhost dhcp]# ls /var/www/html/centos/7/x86_64/
CentOS_BuildTag  EULA  images    LiveOS    repodata              RPM-GPG-KEY-CentOS-Testing-7
EFI              GPL   isolinux  Packages  RPM-GPG-KEY-CentOS-7  TRANS.TBL

[root@localhost dhcp]# systemctl start httpd.service

mark

四. kickstart

制作kickstart文件
mark
mark
mark
mark
mark
mark
mark
mark
mark
mark
mark
mark

[root@localhost ~]# ksvalidator centos7.cfg

[root@localhost dhcp]# mkdir /var/www/html/kickstarts
[root@localhost dhcp]# vim /var/www/html/kickstarts/centos7.cfg
#platform=x86, AMD64, or Intel EM64T
#version=DEVEL
# Install OS instead of upgrade
install
# Keyboard layouts
# old format: keyboard us
# new format:
keyboard --vckeymap=us --xlayouts='us'
# Root password
rootpw --iscrypted $1$hgfvQffN$tXNj5mQldgQt4ziW1QhNF0
# Use network installation
url --url="http://172.16.0.11/centos/7/x86_64"
# System language
lang en_US
# Firewall configuration
firewall --disabled
# System authorization information
auth  --useshadow  --passalgo=sha512
# Use graphical install
graphical
# Run the Setup Agent on first boot
firstboot --enable
# SELinux configuration
selinux --disabled
# Do not configure the X Window System
skipx

# System services
services --disabled="chronyd"
ignoredisk --only-use=sda
# Network information
network  --bootproto=dhcp --device=eno16777984
# Reboot after installation
reboot
# System timezone
timezone Asia/Shanghai --ntpservers=3.centos.pool.ntp.org,0.centos.pool.ntp.org,2.centos.pool.ntp.org,1.centos.pool.ntp.org
# System bootloader configuration
bootloader --location=mbr --boot-drive=sda
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part /boot --asprimary --fstype="xfs" --size=1000
part swap --fstype="swap" --size=8000
part / --fstype="xfs" --grow --size=1

%packages
@^minimal
@core

%end

五. pxeliunx

配置yum仓库, 使用公网yum仓库亦可
[root@localhost ~]# vim /etc/yum.repos.d/CentOS-Base.repo
[base]
name=CentOS-$releasever - Base
#mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os&infra=$infra
baseurl=file:///var/www/html/centos/7/x86_64/
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

[root@localhost Packages]# yum -y install syslinux

[root@localhost Packages]# rpm -ql syslinux | grep "pxelinux.0"
/usr/share/syslinux/gpxelinux.0
/usr/share/syslinux/pxelinux.0
拷贝pxelinux到tftp工作目录
[root@localhost Packages]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
拷贝内核和initrd文件
[root@localhost ~]# cp /var/www/html/centos/7/x86_64/images/pxeboot/{vmlinuz,initrd.img} /var/lib/tftpboot/

准备字符界面需要的文件
[root@localhost ~]# cp /usr/share/syslinux/{chain.c32,menu.c32,memdisk,mboot.c32} /var/lib/tftpboot/
准备引导界面目录
[root@localhost tftpboot]# cd
[root@localhost ~]# cd /var/lib/tftpboot/
[root@localhost tftpboot]# ls
chain.c32  initrd.img  mboot.c32  memdisk  menu.c32  pxelinux.0  vmlinuz
[root@localhost tftpboot]# mkdir pxelinux.cfg
[root@localhost tftpboot]# cd pxelinux.cfg/
[root@localhost pxelinux.cfg]# vim default
default menu.c32
        prompt 5
        timeout 30
        MENU TITLE CentOS 7 PXE Menu

        LABEL linux
        MENU LABEL Install CentOS 7 x86_64
        KERNEL vmlinuz
        APPEND initrd=initrd.img inst.repo=http://172.16.0.11/centos/7/x86_64
        LABEL linux_autoinst
        MENU LABEL Install CentOS 7 x86_64 auto
        KERNEL vmlinuz
        APPEND initrd=initrd.img inst.repo=http://172.16.0.11/centos/7/x86_64 ks=http://172.16.0
.11/kickstarts/centos7.cfg



启动httpd服务(之前启动过,此处应不需要重启)
[root@localhost pxelinux.cfg]# systemctl start httpd.service

六. 验证

创建虚拟机并启动
mark
mark
mark
mark
mark
mark

注意: 此处网关设置得不太合理, 并不是pxe服务器作为网关,导致无法上网, 签名配置文件中已改成正确的网关

问题: yum -y install syslinux时,报Error downloading packages:

syslinux-4.05-13.el7.x86_64: [Errno 256] No more mirrors to try.

解决方法:

[root@localhost Packages]# rm -fr /var/cache/yum/*
[root@localhost Packages]# yum clean all

原创文章,作者:hansj,如若转载,请注明出处:http://www.178linux.com/77410

(0)
hansjhansj
上一篇 2017-06-03
下一篇 2017-06-03

相关推荐

  • linux 生产常用命令

    hostname 显示当前的主机名pwd 显示当前工作的目录wwhowhoami显示当前用户及已建立的ssh链接useradd 新建一个普通用户passwd 修改用户的密码which 查看系统命令所对应的路径type 查询命令是否属于内部命令或者外部命令hash 哈希 把一个命令一个文本通过某种算法生产一串字符df 查看系统分区hash -l 加快命令查询执…

    Linux干货 2017-03-28
  • 网络管理之配置静态ip和多网卡绑定

    不知怎的,这几天教室的网络异常诡异,各种不稳定啊。原先小编都是通过自动获取(dhcp)的方式来进行网络连接的,现在这种网络情况下需要(static)的方式来配置一个固定的ip。步骤如下: 一、在终端中输入:vim /etc/sysconfig/network-scripts/ifcfg-eth0 二、进行编辑并保存退出 三、重启网络服务:service ne…

    2017-09-10
  • week5

    1、显示当前系统上root、fedora或user1用户的默认shell; useradd fedora useradd user1 egrep "^(root|fedora|user1)" /etc/passwd | cut -d: -f1,7 2、找出/e…

    Linux干货 2016-11-24
  • 0805随堂练习

    文本处理练习: 1.找出本机ip地址  [root@localhost ~]# ifconfig |head -2 |tail -1 |tr -s ' ' ':' |cut -d: -f3  10.1.252.221 2.查看本机分区最大的利用率  [root@localhost ~]# …

    Linux干货 2016-08-07
  • Linux ansible 服务

                      Linux ansible 服务 Ansible:    运维工具的分类: agent:基于专用的agent程序完成管理功能,puppet, func, zabbix, … agentless:基于ss…

    系统运维 2016-11-19
  • 计算机的组成及其功能

    1.计算机的组成及其功能 1.1计算机的硬件基本结构 从ENIAC到当前最先进的计算机都采用的是冯·诺依曼体系结构分别是:控制器,运算器,存储器,输入与输出设备 控制器:将指令逐条从存储器中取出,经译码分析后向全机发出相应         的操作控制信号作用于其他部件,使各部件有…

    Linux干货 2016-10-28