PXE遠程裝機服務批量部署LINUX系統

1、搭建FTP服務並配置ftp的本地yum源:java

# mkdir /mnt/cdrom
# mount /dev/sr0 /mnt/cdrom/    # 掛載Centos7光盤
# yum -y install vsftpd    # 安裝ftp服務
# vim /etc/vsftpd/vsftpd.conf    # 修改ftp配置文件,添加下面三行到connect_from_port_20=YES後面
 pasv_enable=YES    # 使用被動模式
 pasv_min_port=3001    # 設定被動模式監聽端口號範圍
 pasv_max_port=3100    # 設定被動模式監聽端口號範圍
# systemctl start vsftpd.service    # 啓動vsftp服務
# mkdir /var/ftp/yum    # ftp目錄下建立yum目錄
# cp -rf /mnt/cdrom/* /var/ftp/yum    # 將光盤的全部內容複製到yum目錄下做爲yum源
# mkdir /etc/yum.repos.d/old
# mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/old    # 移動備份下現有的yum源配置文件
# vim /etc/yum.repos.d/CentOS-cr.repo    # 建立一個新的yum源配置文件,內容以下:
[cr]
name=CentOS-$releasever - cr
baseurl=ftp://192.168.8.10/yum
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
enabled=1
# yum clean all
# yum makecache


2、搭建DHCP服務:node

# yum -y install dhcp
# cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcp.conf    # 經過幫助模板建立DHCP配置文件
# vim /etc/dhcp/dhcpd.conf    # 修改DHCP配置文件
default-lease-time 600;
max-lease-time 7200;
log-facility local7;
subnet 192.168.8.0 netmask 255.255.255.0 {
  range 192.168.8.100 192.168.8.200;
  option routers 192.168.8.2;
  option broadcast-address 192.168.8.255;
  default-lease-time 600;
  max-lease-time 7200;
  next-server 192.168.8.10;    # 指定PXE引導服務器
  filename "pxelinux.0";    # 指定引導文件
}
# systemctl start dhcpd.service    # 啓動DHCP服務


3、搭建TFTP服務和syslinux:linux

# yum -y install tftp-server
# yum -y install syslinux
# vim /etc/xinetd.d/tftp    # 開啓tftp服務,由於tftp是xinetd控制的,因此要修改相關配置文件後重啓xinetd服務
  disable= no    # 把yes改爲no表明開啓tftp服務
# systemctl start xinetd.service
# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
# cp /var/ftp/yum/isolinux/{vmlinuz,initrd.img,vesamenu.c32,boot.msg} /var/lib/tftpboot/
# mkdir /var/lib/tftpboot/pxelinux.cfg
# cp /var/ftp/yum/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default    # 複製並重命名爲default
# vim /var/lib/tftpboot/pxelinux.cfg/default    # 修改default文件,添加下面的內容,注意:記得同時刪除後面原有的menu default
  label centos7
  menu label ^Install CentOS 7 Li networkserver
  menu default
  kernel vmlinuz
  append initrd=initrd.img inst.stage2=ftp://192.168.8.10/yum inst.ks=ftp://192.168.8.10/ks.cfg quiet    # 指定安裝系統軟件時的軟件地址,和安裝系統的配置文件


4、安裝system-config-kickstart並配置生成上面指定的配置文件:vim

# yum -y install system-config-kickstart
# system-config-kickstart    # 進入圖形化配置生成界面,配置完成後將文件保存在上面指定的位置,即:/var/ftp/ks.cfg

blob.png

固然,這個配置文件也能夠手動編輯了:centos

# vim /var/ftp/ks.cfg
    #platform=x86, AMD64, or Intel EM64T
    #version=DEVEL
    # Install OS instead of upgrade
    install
    # Keyboard layouts
    keyboard 'us'# Reboot after installation
    reboot
    # Root password
    rootpw --iscrypted $1$uP/6KVVM$domD73qgFbtoo5.Udls1V.
    # System timezone
    timezone Asia/Shanghai
    # Use network installation
    url --url="ftp://192.168.8.10/yum"
    # System language
    lang en_US
    # Firewall configuration
    firewall --enabled --ssh
    # Network information
    network  --bootproto=dhcp --device=eth0
    # System authorization information
    auth  --useshadow  --passalgo=sha512
    # Use graphical install
    graphical
    # Run the Setup Agent on first boot
    firstboot --enable
    # SELinux configuration
    selinux --enforcing
    # System bootloader configuration
    bootloader --location=mbr
    # Clear the Master Boot Record
    zerombr
    # Partition clearing information
    clearpart --all --initlabel 
    # Disk partitioning information
    part /boot --fstype="ext4" --size=1024
    part /home --fstype="ext4" --size=4096
    part swap --fstype="swap" --size=2048
    part / --fstype="ext4" --size=10240
    %packages    # 這一段是將要安裝的軟件包組
    @base
    @core
    @desktop-debugging
    @dial-up
    @directory-client
    @fonts
    @gnome-desktop
    @guest-agents
    @guest-desktop-agents
    @input-methods
    @internet-browser
    @java-platform
    @multimedia
    @network-file-system-client
    @networkmanager-submodules
    @print-client
    @x11
    kexec-tools
    %end
    %post --interpreter=/bin/bash    # 這一段是須要部署完成後運行的腳本,非必須,下面兩個腳本分別是我加的配置yum源和更新ssh
    mkdir /etc/yum/old
    cp -rf /etc/yum.repos.d/* /etc/yum/old
    rm -rf /etc/yum.repos.d/*
    echo '# CentOS-Base.repo
    #
    # The mirror system uses the connecting IP address of the client and the
    # update status of each mirror to pick mirrors that are updated to and
    # geographically close to the client.  You should use this for CentOS updates
    # unless you are manually picking other mirrors.
    #
    # If the mirrorlist= does not work for you, as a fall back you can try the 
    # remarked out baseurl= line instead.
    #
    #
     
    [base]
    name=CentOS-$releasever - Base - mirrors.aliyun.com
    failovermethod=priority
    baseurl=ftp://192.168.8.10/yum
    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
    gpgcheck=1
    enabled=1
    ' >/etc/yum.repos.d/CentOS7.repo
    wget ftp://192.168.8.10/pub/openssh-7.6p1.tar.gz
    tar -xf openssh-7.6p1.tar.gz
    cd openssh-7.6p1
    yum -y install gcc
    yum install -y zlib-devel
    yum -y install openssl-devel
    ./configure --prefix=/usr --sysconfdir=/etc/ssh
    make
    rpm -e --nodeps `rpm -qa | grep openssh`
    cp -rf /etc/ssh ./ssh.bak
    rm -rf /etc/ssh/*
    make install
    echo "#$OpenBSD: sshd_config,v 1.101 2017/03/14 07:19:07 djm Exp $
    # This is the sshd server system-wide configuration file.  See
    # sshd_config(5) for more information.
    # This sshd was compiled with PATH=/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/ssh/bin
    # The strategy used for options in the default sshd_config shipped with
    # OpenSSH is to specify options with their default value where
    # possible, but leave them commented.  Uncommented options override the
    # default value.
    #Port 22
    #AddressFamily any
    #ListenAddress 0.0.0.0
    #ListenAddress ::
    #HostKey /etc/ssh/ssh_host_rsa_key
    #HostKey /etc/ssh/ssh_host_dsa_key
    #HostKey /etc/ssh/ssh_host_ecdsa_key
    #HostKey /etc/ssh/ssh_host_ed25519_key
    # Ciphers and keying
    #RekeyLimit default none
    # Logging
    #SyslogFacility AUTH
    #LogLevel INFO
    # Authentication:
    #LoginGraceTime 2m
    PermitRootLogin yes
    #StrictModes yes
    #MaxAuthTries 6
    #MaxSessions 10
    #PubkeyAuthentication yes
    # The default is to check both .ssh/authorized_keys and .ssh/authorized_keys2
    # but this is overridden so installations will only check .ssh/authorized_keys
    AuthorizedKeysFile.ssh/authorized_keys
    #AuthorizedPrincipalsFile none
    #AuthorizedKeysCommand none
    #AuthorizedKeysCommandUser nobody
    # For this to work you will also need host keys in /etc/ssh/ssh_known_hosts
    #HostbasedAuthentication no
    # Change to yes if you don't trust ~/.ssh/known_hosts for
    # HostbasedAuthentication
    #IgnoreUserKnownHosts no
    # Don't read the user's ~/.rhosts and ~/.shosts files
    #IgnoreRhosts yes
    # To disable tunneled clear text passwords, change to no here!
    #PasswordAuthentication yes
    #PermitEmptyPasswords no
    # Change to no to disable s/key passwords
    #ChallengeResponseAuthentication yes
    # Kerberos options
    #KerberosAuthentication no
    #KerberosOrLocalPasswd yes
    #KerberosTicketCleanup yes
    #KerberosGetAFSToken no
    # GSSAPI options
    #GSSAPIAuthentication no
    #GSSAPICleanupCredentials yes
    # Set this to 'yes' to enable PAM authentication, account processing,
    # and session processing. If this is enabled, PAM authentication will
    # be allowed through the ChallengeResponseAuthentication and
    # PasswordAuthentication.  Depending on your PAM configuration,
    # PAM authentication via ChallengeResponseAuthentication may bypass
    # the setting of "PermitRootLogin without-password".
    # If you just want the PAM account and session checks to run without
    # PAM authentication, then enable this but set PasswordAuthentication
    # and ChallengeResponseAuthentication to 'no'.
    #UsePAM no
    #AllowAgentForwarding yes
    #AllowTcpForwarding yes
    #GatewayPorts no
    #X11Forwarding yes
    #X11DisplayOffset 10
    #X11UseLocalhost yes
    #PermitTTY yes
    #PrintMotd yes
    #PrintLastLog yes
    #TCPKeepAlive yes
    #UseLogin no
    #PermitUserEnvironment no
    #Compression delayed
    #ClientAliveInterval 0
    #ClientAliveCountMax 3
    #UseDNS no
    #PidFile /var/run/sshd.pid
    #MaxStartups 10:30:100
    #PermitTunnel no
    #ChrootDirectory none
    #VersionAddendum none
    # no default banner path
    #Banner none
    # override default of no subsystems
    Subsystemsftp/usr/libexec/sftp-server
    # Example of overriding settings on a per-user basis
    #Match User anoncvs
    #X11Forwarding no
    #AllowTcpForwarding no
    #PermitTTY no
    #ForceCommand cvs server
    ">/etc/ssh/sshd_config
    cp /openssh-7.6p1/contrib/redhat/sshd.init /etc/init.d/sshd
    setenforce 0
    chkconfig --add sshd
    systemctl start sshd.service
    %end


5、配置防火牆,開放相關服務和端口:bash

# firewall-cmd --permanent --add-service=ftp    # 防火牆開啓ftp服務(tcp21)
# firewall-cmd --permanent --add-service=dhcp    # 防火牆開啓DHCP服務(udp67)
# firewall-cmd --permanent --add-port=69/udp    # 防火牆開啓tftp服務(udp69)
# firewall-cmd --permanent --add-port=3001-3100/tcp    # 防火牆開啓ftp被動監聽的端口段
# systemctl restart firewalld.service    # 重啓防火牆使配置生效,或者firewall-cmd--reload


6、測試:服務器

只要要安裝系統的主機和此服務器在一個網段或者其餘網段能經過DHCP中繼獲取地址就能夠自動安裝了session

相關文章
相關標籤/搜索