基于pxe部署系統

一、前言

在生產環境中,我們經常遇到需要部署部署多臺服務器。如果我們每部署一臺服務器都要拿著系統盤到機房部署,守在服務器面前,那么我們的效率是十分低下的。況且有時候機房并不在我們身邊。那么我們可以通過讓機房值班人員為每臺服務器配置好遠程管理卡,運維人員通過遠程管理卡,遠程登入服務器進行操作。

二、pxe原理

pxe原理是通過服務器上網卡中支持的pxe啟動,通過廣播的方式獲取ip地址與下一個服務器的ip地址,pxe客戶端在tftp服務器上下載pxelinux.0文件,pxe客戶端根據pxelinux.0的執行結果,通過tftp服務器加載kernel及ramdisk文件,從而引導系統。具體原理可查考下圖

1.png

三、開始部署pxe服務器

3.1  部署dhcp服務

3.1.1 安裝dhcp服務器并關閉selinux及iptables

[root@localhost ~]# yum install dhcp –y
[root@localhost ~]# setenforce 0            #設置selinux為permissive模式        
[root@localhost ~]# getenforce
Permissive
[root@localhost ~]# service iptables stop   #關閉防火墻

3.1.2 配置dhcp服務器

[root@localhost ~]# mv /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample /etc/dhcp/dhcpd.conf
subnet 192.168.19.0 netmask 255.255.255.0 {
  range 192.168.19.100 192.168.19.200;        #dhcp地址池    
  filename "pxelinux.0"                       #下一個尋找的文件                    
  server-name "192.168.19.136"                #下一個尋找的服務器地址            
}

3.1.3設置開機啟動

[root@localhost ~]# chkconfig dhcpd on
[root@localhost ~]# chkconfig --list dhcpd
dhcpd           0:off         1:off         2:on 3:on 4:on 5:on 6:off
[root@localhost ~]# service dhcpd start

3.2 配置tftp服務器

 [root@localhost ~]# yum install -y tftp-server
         service tftp
{
         socket_type        = dgram
         protocol           = udp
         wait               = yes
         user               = root
         server             = /usr/sbin/in.tftpd
         server_args        = -s /var/lib/tftpboot
         disable            = no                    #設置tftp-server開機自動啟動                
         per_source         = 11
         cps                = 100 2
         flags              = IPv4
}

3.3配置pxe工作環境

3.3.1安裝syslinux

[root@localhost ~]# yum install -y syslinux
[root@localhost tftpboot]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/

3.3.2 安裝httpd       

[root@localhost tftpboot]# yum install -y httpd
[root@localhost tftpboot]# chkconfig httpd on
[root@localhost tftpboot]# service httpd start

3.3.3提供kernel,ramdisk等文件

[root@localhost tftpboot]# mount /dev/sr0 /mnt/cdrom
[root@localhost tftpboot]# mount --bind /mnt/cdrom /var/www/html/centos/x86_64
[root@localhost tftpboot]# cd /mnt/cdrom/images/pxeboot/
[root@localhost pxeboot]# cp vmlinuz initrd.img /var/lib/tftpboot/
[root@localhost isolinux]# cd /mnt/cdrom/isolinux/
[root@localhost isolinux]# cp vesamenu.c32 boot.msg splash.jpg  /var/lib/tftpboot/
[root@localhost isolinux]# mkdir /var/lib/tftpboot/pxelinux.cfg
[root@localhost isolinux]# cp isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default

3.3.4提供kickstart文件

4.png

[root@localhost tftpboot]# yum install -y system-config-kickstart
[root@localhost tftpboot]# cp /root/ks.cfg /var/www/html/
#kickstart文件部分示例 
# Firewall configuration
firewall --enabled --service=ssh
# Install OS instead of upgrade
install
# Use network installation
# Firewall configuration
firewall --enabled --service=ssh
# Install OS instead of upgrade
install
# Use network installation
url --url="http://192.168.19.136/centos/x86_64"        #指定安裝源    
# Root password
rootpw --plaintext centos                              #設置root密碼                            
# System authorization information
auth  --useshadow  --passalgo=md5
# Use text mode install
text                                                   #文本模式安裝                                  firstboot --disable
# System keyboard
keyboard us                                            #鍵盤類型                                     
# System language
lang en_US                                             #語言
# SELinux configuration
selinux --enforcing                                    #selinux模式
# Installation logging level
logging --level=info
# Reboot after installation
reboot
# System timezone
timezone  Asia/Shanghai
# Network information
network  --bootproto=dhcp --device=eth0 --onboot=on    #連網方式
# System bootloader configuration
bootloader --append="crashkernel=auto rhgb quiet" --location=mbr --driveorder="sda"
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part /boot --fstype="ext4" --size=200                  #創建/boot分區
part / --fstype="ext4" --grow --size=1                 #創建/ 分區

四、測試

關閉vmware的dhcp功能

2.png

從pxe啟動后,設置ks文件

3.png

安裝

5.png

參考文獻:http://www.cnblogs.com/mchina/p/centos-pxe-kickstart-auto-install-os.html

 

原創文章,作者:成吉思汗,如若轉載,請注明出處:http://www.www58058.com/8000

(0)
成吉思汗成吉思汗
上一篇 2015-09-14 09:23
下一篇 2015-09-14 09:31

相關推薦

  • Java中的Map List Set等集合類

    Map List Set等集合類: 一、概述 在JAVA的util包中有兩個所有集合的父接口Collection和Map,它們的父子關系: +Collection 這個接口extends自 –java.lang.Iterable接口 ├+List(接口 代表有序,可重復的集合。列表) │├ ArreyList   &…

    Linux干貨 2015-04-07
  • Tomcat的安裝和簡介

    第一部分: ????在linux系統平臺上安裝Tomcat的總結 ????1.到http://jakarta.apache.org/site/binindex.cgi(去下載一個tomcat版本各種版本都有),zip或者tar.bz2的>壓縮包,將其解壓到/usr/local/的目錄下面. ????2.配置環境變量:為了在以后系統啟動后就配置好Tomc…

    2017-11-05
  • ansible

    Ansible 1、  特性: 模塊化:調用特定的模塊,完成特定任務; 基于Python語言實現部署簡單:agentless; 支持自定義模塊; 支持playbook;編排任務; ansible自身并不實現任何管理任務,它的所有管理任務,統統都使用模塊完成;             &nb…

    Linux干貨 2016-11-11
  • vim編輯器

    一、vim編輯器簡介     文本:ASCII,Unicode     文本編輯種類:     行編輯器:sed     全屏編輯器:nano,vi     v…

    Linux干貨 2016-08-10
  • Linux Cluster之Keepalived + Nginx的實現

      一、實驗環境 http server1與http server2組成web集群,由nginx服務器實現負載均衡代理,使用keepalived保證nginx服務的高可用。通過虛擬IP192.168.154.177對外提供web服務。 實驗目的: 1)當Nginx server1上的nginx服務異常時,由nginx server2提供反帶服務。 …

    2016-11-02
  • 初識shell腳本編程

    shell腳本基礎 shell腳本是包含一些命令或聲明,并符合一定格式的文本文件 一般格式要求: 1.首行shebang機制 #!/bin/bash #!/bin/python #!/usr/bin/perl 2.注釋信息 以#開頭,可寫明腳本用途,作者,版本,時間等 3.腳本正文內容, 創建shell腳本 以bash為例 第一行定格#!/bin/bash …

    Linux干貨 2016-08-15

評論列表(2條)

  • stanley
    stanley 2015-09-14 09:29

    有下篇嗎,過程挺詳細,只是步驟好順利的樣子,我們公司原來有同學在折騰這個過程沒有預期順利,總是卡在ip獲取上

    • 成吉思汗
      成吉思汗 2015-09-15 08:49

      @stanley無下篇,自己電腦上做的實驗,把虛擬機的dhcp功能關閉,只要服務器上dhcp配置好了,就能獲取到ip。其實也沒文章寫的順利,主要卡在kickstart文件上。

欧美性久久久久