天天看點

kickstart無人值守自動安裝作業系統

PXE是什麼?

PXE(Pre-boot Execution     Environment,預啟動執行環境)是由Intel公司開發的最新技術,工作于Client/Server的網絡模式,支援工作站通過網絡從遠端伺服器下載下傳映像,并由此支援通過網絡啟動作業系統,在啟動過程中,終端要求伺服器配置設定IP位址,再用TFTP(trivial     file transfer protocol)或MTFTP(multicast trivial file transfer     protocol)協定下載下傳一個啟動軟體包到本機記憶體中執行,由這個啟動軟體包完成終端基本軟體設定,進而引導預先安裝在伺服器中的終端作業系統。

嚴格來說,PXE 并不是一種安裝方式,而是一種引導方式。進行 PXE 安裝的必要條件是在要安裝的計算機中必須包含一個 PXE 支援的網卡(NIC),即網卡中必須要有 PXE     Client。PXE 協定可以使計算機通過網絡啟動。此協定分為     Client端和 Server 端,而PXE     Client則在網卡的 ROM 中。當計算機引導時,BIOS 把 PXE     Client 調入記憶體中執行,然後由 PXE Client 将放置在遠端的檔案通過網絡下載下傳到本地運作。運作 PXE 協定需要設定 DHCP 伺服器和 TFTP 伺服器。DHCP 伺服器會給 PXE     Client(将要安裝系統的主機)配置設定一個 IP 位址,由于是給 PXE     Client 配置設定 IP 位址,是以在配置 DHCP 伺服器時需要增加相應的 PXE 設定。此外,在 PXE     Client 的 ROM 中,已經存在了 TFTP     Client,那麼它就可以通過 TFTP 協定到 TFTP     Server 上下載下傳所需的檔案了。

pxe小結:

PXE,全稱Pre-boot     Execution Environment 預啟動執行環境

通過網絡接口啟動計算機,不依賴本地儲存設備或本地已安裝的作業系統

C/S的工作模式

由intel公司開發的最新技術

PXE用戶端會調用IP,UDP,DHCP,TFTP等網絡協定

PXE用戶端其實是指網卡有PXE     client,存放在網卡的ROM中,當伺服器啟動時候bios會把pxe     client調到記憶體中執行

PXE的工作原理

PXE client從自己的PXE網卡啟動,向本網絡中DHCP伺服器請求IP

DHCP 伺服器傳回給客戶機IP以及PXE檔案放置位置(該檔案放置在TFTP上)

PXE client向本網絡中的TFTP伺服器索取pxelinux.0,pxelinux.cfg/default、vmlinuz、initrd.img等檔案

根據pxelinux.0得到的結果,執行該檔案

根據pxelinux.0的執行結果,通過TFTP伺服器加載核心和檔案系統

進入安裝畫面,此時可以通過選擇HTTP、FTP、NFS方式進行安裝

圖解:

<a href="http://s3.51cto.com/wyfs02/M02/83/77/wKiom1dz2_uDYDLbAAE5PKiWb2w705.jpg-wh_500x0-wm_3-wmp_4-s_4193555089.jpg" target="_blank"></a>

什麼是kickstart

Kickstart是一種無人值守的安裝方式。它的工作原理是在安裝過程中記錄典型的需要人工幹預填寫的各種參數,并生成一個名為ks.cfg的檔案。如果在安裝過程中(不隻局限于生成Kickstart安裝檔案的機器)出現要填寫參數的情況,安裝程式首先會去查找Kickstart生成的檔案,如果找到合适的參數,就采用所找到的參數;如果沒有找到合适的參數,便需要安裝者手工幹預了。是以,如果Kickstart檔案涵蓋了安裝過程中可能出現的所有需要填寫的參數,那麼安裝者完全可以隻告訴安裝程式從何處取ks.cfg檔案,然後就去忙自己的事情。等安裝完畢,安裝程式會根據ks.cfg中的設定重新開機系統,并結束安裝。

圖解:(借鑒與網上)

<a href="http://s1.51cto.com/wyfs02/M00/83/77/wKiom1dz3GrynO9uAAIkO6DWvwA650.png-wh_500x0-wm_3-wmp_4-s_2560748963.png" target="_blank"></a>

系統環境

實驗環境:VMware Workstations 11

系統平台:

[root@m01 ~]# cat /etc/redhat-release

CentOS release 6.7 (Final)

[root@m01 ~]# uname -rm

2.6.32-573.el6.x86_64 x86_64

[root@m01 ~]# getenforce

Disabled

[root@m01 ~]# /etc/init.d/iptables status

iptables:未運作防火牆。

網絡模式:NAT模式

注意:

虛拟機網卡采用NAT模式,不要使用橋接模式,因為稍後我們會搭建DHCP伺服器,在同一區域網路多個DHCP服務會有沖突。

VMware的NAT模式的dhcp服務也關閉,避免幹擾。

<a href="http://s5.51cto.com/wyfs02/M01/83/77/wKiom1dz3JTgYg0FAAAHnELqIwc159.png-wh_500x0-wm_3-wmp_4-s_1284020840.png" target="_blank"></a>

安裝服務程式

從上圖的pxe+kickstart工作原理圖可以看出,這裡需要DHCP,TFTP,HTTP根據架構需求有時候還需要NFS服務,下面我們先安裝這個幾個服務

[root@m01 ~]# yum install -y httpd dhcp tftp-server

[root@m01 ~]# rpm -qa httpd dhcp tftp-server

tftp-server-0.49-8.el6.x86_64

dhcp-4.1.1-51.P1.el6.centos.x86_64

httpd-2.2.15-53.el6.centos.x86_64

[root@m01 ~]#

DHCP服務配置

[root@m01 ~]# vim /etc/dhcp/dhcpd.conf

ddns-update-style interim;

ignore client-updates;

filename "pxelinux.0";             #pxelinux 啟動檔案位置;

next-server 172.16.1.61;

subnet 172.16.1.0 netmask 255.255.255.0 {

        option routers                  172.16.1.61;

        option subnet-mask              255.255.255.0;

        range dynamic-bootp 172.16.1.100 172.16.1.200;

        default-lease-time 21600;

        max-lease-time 43200;

}

range  172.16.1.100 172.16.1.200         # 可配置設定的起始IP-結束IP

option subnet-mask 255.255.255.0;    # 設定netmask

default-lease-time 21600;            # 設定預設的IP租用期限

max-lease-time 43200;                # 設定最大的IP租用期限

next-server 10.0.0.7;                # 告知用戶端TFTP伺服器的ip

filename "/pxelinux.0";              # 告知用戶端從TFTP根目錄下載下傳pxelinux.0檔案

[root@m01 ~]# /etc/init.d/dhcpd start

正在啟動 dhcpd:                                           [确定]

[root@m01 ~]# netstat -lntup|grep dhcp

udp        0      0 0.0.0.0:67                  0.0.0.0:*                               1528/dhcpd

** 多網卡預設監聽eth0,指定DHCP監聽eth1網卡**

[root@m01 ~] vim /etc/sysconfig/dhcpd

# Command line options here

DHCPDARGS=eth1  # 指定監聽網卡

配置TFTP服務

TFTP簡介

TFTP(Trivial File Transfer Protocol,簡單檔案傳輸協定)是TCP/IP協定族中的一個用來在客戶機與伺服器之間進行簡單檔案傳輸的協定,提供不複雜、開銷不大的檔案傳輸服務。端口号為69。

[root@m01 ~]# vim /etc/xinetd.d/tftp

# default: off

# description: The tftp server serves files using the trivial file transfer \

#       protocol.  The tftp protocol is often used to boot diskless \

#       workstations, download configuration files to network-aware printers, \

#       and to start the installation process for some operating systems.

service tftp

{

        socket_type             = dgram

        protocol                = udp

        wait                    = yes

        user                    = root

        server                  = /usr/sbin/in.tftpd

        server_args             = -s /var/lib/tftpboot

        disable                 = no

        per_source              = 11

        cps                     = 100 2

        flags                   = IPv4

[root@m01 ~]# /etc/init.d/xinetd start

正在啟動 xinetd:                                          [确定]

[root@m01 ~]# netstat -lntup|grep 69

udp        0      0 0.0.0.0:69                  0.0.0.0:*                               1584/xinetd

server_args一行是配置伺服器的檔案存放的位置,就是進行tftp傳輸的時候,都是從該檔案夾中搜尋檔案的

配置HTTP服務

[root@m01 ~]# cd /var/www/html/

[root@m01 html]# mkdir CentOS-6.7

[root@m01 html]# mount /dev/cdrom /var/www/html/CentOS-6.7/

mount: block device /dev/sr0 is write-protected, mounting read-only

[root@m01 html]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3       8.8G  1.5G  7.0G  17% /

tmpfs           491M     0  491M   0% /dev/shm

/dev/sda1       190M   36M  145M  20% /boot

/dev/sr0        3.7G  3.7G     0 100% /var/www/html/CentOS-6.7

[root@m01 html]# /etc/init.d/httpd start

正在啟動 httpd:httpd: apr_sockaddr_info_get() failed for m01

httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName

                                                           [确定]

[root@m01 html]# sed -i "277i ServerName 127.0.0.1:80" /etc/httpd/conf/httpd.conf 這個指令就是消除上面那個報錯的

[root@m01 html]# /etc/init.d/httpd restart

停止 httpd:                                               [确定]

正在啟動 httpd:

浏覽器通路pxe伺服器,測試配置是否正确

<a href="http://s2.51cto.com/wyfs02/M00/83/76/wKioL1dz3LfQXIPoAADlbcsAmvk510.png-wh_500x0-wm_3-wmp_4-s_509041977.png" target="_blank"></a>

配置支援PXE的啟動程式

PXE引導配置(bootstrap)

syslinux是一個功能強大的引導加載程式,而且相容各種媒體。syslinux是一個小型的Linux作業系統,它的目的是簡化首次安裝Linux的時間,并建立維護或其他特殊用途的啟動盤。如果沒有找到pxelinux.0這個檔案,可以安裝一下syslinux。

[root@m01~]# yum install -y syslinux

[root@m01~]# rpm -qa syslinux

syslinux-4.04-3.el6.x86_64

複制pxelinux.0檔案至tftp的預設目錄中去/var/lib/tftpboot

[root@m01~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/

複制iso 鏡像中的/isolinux/*.msg 至/var/lib/tftpboot/ 檔案夾中

[root@m01 ~]# cp/var/www/html/CentOS-6.7/isolinux/*.msg /var/lib/tftpboot/

複制iso 鏡像中的/image/pxeboot/initrd.img和vmlinux 至/var/lib/tftpboot/ 檔案夾中

[root@m01 ~]# cp/var/www/html/CentOS-6.7/images/pxeboot/initrd.img /var/lib/tftpboot/

[root@m01 ~]# cp/var/www/html/CentOS-6.7/images/pxeboot/vmlinuz /var/lib/tftpboot

将iso 鏡像中的/isolinux目錄中的isolinux.cfg複制到pxelinux.cfg目錄中,同時更改檔案名稱為default

這裡也可以直接全部複制過去:

cp-a /var/www/html/CentOS-6.7/isolinux/* /var/lib/tftpboot/

[root@m01~]# mkdir -p /var/lib/tftpboot/pxelinux.cfg

[root@m01~]# cp /var/www/html/CentOS-6.7/isolinux/isolinux.cfg/var/lib/tftpboot/pxelinux.cfg/default

pxe配置檔案default解析

[root@m01 ~]# vim/var/lib/tftpboot/pxelinux.cfg/default

default ks#預設啟動的是 'label ks' 中标記的啟動核心

default vesamenu.c32  # 預設加載一個菜單

#prompt 1             # 開啟會顯示指令行'boot:'提示符。prompt值為0時則不提示,将會直接啟動'default'參數中指定的内容。

timeout 600           # timeout時間是引導時等待使用者手動選擇的時間,設為1可直接引導,機關為1/10秒。

display boot.msg#顯示某個檔案的内容,注意檔案的路徑。預設是在/var/lib/tftpboot/ 目錄下。也可以指定位類似 '/install/boot.msg'這樣的,路徑+檔案名。

F1 boot.msg #按下 'F1' 這樣的鍵後顯示的檔案。

F2 options.msg 

F3 general.msg 

F4 param.msg 

F5 rescue.msg

# 菜單背景圖檔、标題、顔色。

menubackground splash.jpg

menutitle Welcome to CentOS 6.7!

menucolor border 0 #ffffffff #00000000

menucolor sel 7 #ffffffff #ff000000

menucolor title 0 #ffffffff #00000000

menucolor tabmsg 0 #ffffffff #00000000

menucolor unsel 0 #ffffffff #00000000

menucolor hotsel 0 #ff000000 #ffffffff

menucolor hotkey 7 #ffffffff #ff000000

menucolor scrollbar 0 #ffffffff #00000000

# label指定在boot:提示符下輸入的關鍵字,比如boot:linux[ENTER],這個會啟動labellinux下标記的kernel和initrd.img檔案。

label linux      # 一個标簽就是前面圖檔的一行選項。

  menu label ^Install or upgrade an existingsystem

  menu default

 kernel vmlinuz  # 指定要啟動的核心。同樣要注意路徑,預設是/tftpboot目錄。

 append initrd=initrd.img # 指定追加給核心的參數,initrd.img是一個最小的linux系統

labelvesa

  menu label Install system with ^basic videodriver

  kernel vmlinuz

  append initrd=initrd.img nomodeset

labelrescue

  menu label ^Rescue installed system

  append initrd=initrd.img rescue

labellocal

  menu label Boot from ^local drive

  localboot 0xffff

labelmemtest86

  menu label ^Memory test

  kernel memtest

  append -

新開虛拟機測試

這裡可以新開一個虛拟機網卡設定為NAT模式,開機新的虛拟機,發現會擷取到172.16.1.x網段的一個IP位址

在Installation Method這一步,如果是選擇URL,後面我要輸入http://172.16.1.61/CentOS-6.7/

在Installation Method這一步,如果是選擇NFS directory,後面的寫法是nfs:172.16.1.61:/data/sys/kickstart/ks.cfg

到這裡的測試你發現還是需要手動的,是以我們要繼續操作達到一鍵自動安裝

建立ks.cfg檔案

通常,我們在安裝作業系統的過程中,需要大量的和伺服器互動操作,為了減少這個互動過程,kickstart就誕生了。使用這種kickstart,隻需事先定義好一個Kickstart自動應答配置檔案ks.cfg(通常存放在安裝伺服器上),并讓安裝程式知道該配置檔案的位置,在安裝過程中安裝程式就可以自己從該檔案中讀取安裝配置,這樣就避免了在安裝過程中多次的人機互動,進而實作無人值守的自動化安裝。

生成kickstart配置檔案的三種方法:

方法1、     每安裝好一台Centos機器,Centos安裝程式都會建立一個kickstart配置檔案,記錄你的真實安裝配置。如果你希望實作和某系統類似的安裝,可以基于該系統的kickstart配置檔案來生成你自己的kickstart配置檔案。(生成的檔案名字叫anaconda-ks.cfg位于/root/anaconda-ks.cfg)

方法2、Centos提供了一個圖形化的kickstart配置工具。在任何一個安裝好的Linux系統上運作該工具,就可以很容易地建立你自己的kickstart配置檔案。kickstart配置工具指令為redhat-config-kickstart(RHEL3)或system-config-kickstart(RHEL4,RHEL5).網上有很多用CentOS桌面版生成ks檔案的文章,如果有現成的系統就沒什麼可說。但沒有現成的,也沒有必要去用桌面版,指令行也很簡單。

方法3、閱讀kickstart配置檔案的手冊。用任何一個文本編輯器都可以建立你自己的kickstart配置檔案。

檢視anaconda-ks.cfg檔案

[root@m01 ~]# cat anaconda-ks.cfg

# Kickstart file automatically generated by anaconda.

#version=DEVEL

install

cdrom

lang en_US.UTF-8

keyboard us

network --onboot no --device eth0 --bootproto dhcp --noipv6

network --onboot no --device eth1 --bootproto dhcp --noipv6

rootpw  --iscrypted $6$S5zy08GhFmCSFoJg$IUzRPrNmiIWv2S.nFSpDqN7yuaIvZxBr0Y9s9sh2F5rFZrkbJW0uOIbSUK3eTPOnKgQENgXmkSHMF2tII0Zwb1

firewall --service=ssh

authconfig --enableshadow --passalgo=sha512

selinux --enforcing

timezone --utc Asia/Shanghai

bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb quiet"

# The following is the partition information you requested

# Note that any partitions you deleted are not expressed

# here so unless you clear all partitions first, this is

# not guaranteed to work

#clearpart --none

#part /boot --fstype=ext4 --asprimary --size=200

#part swap --asprimary --size=768

#part / --fstype=ext4 --grow --asprimary --size=200

repo --name="CentOS"  --baseurl=cdrom:sr0 --cost=100

%packages

@base

@compat-libraries

@core

@debugging

@development

@server-policy

@workstation-policy

python-dmidecode

sgpio

device-mapper-persistent-data

systemtap-client

%end[root@m01 ~]#

ks.cfg詳解

官網文檔 

官網自帶中文版,選一下語言即可 

ks.cfg檔案組成大緻分為3段

指令段 

         鍵盤類型,語言,安裝方式等系統的配置,有必選項和可選項,如果缺少某項必選項,安裝時會中斷并提示使用者選擇此項的選項

軟體包段

@groupname:指定安裝的包組

package_name:指定安裝的包

-package_name:指定不安裝的包

在安裝過程中預設安裝的軟體包,安裝軟體時會自動分析依賴關系。

腳本段(可選)

%pre:安裝系統前執行的指令或腳本(由于隻依賴于啟動鏡像,支援的指令很少)

%post:安裝系統後執行的指令或腳本(基本支援所有指令)

關鍵字 含義

install 告知安裝程式,這是一次全新安裝,而不是更新upgrade。

url --url=" " 通過FTP或HTTP從遠端伺服器上的安裝樹中安裝。

url --url="http://10.0.0.7/CentOS-6.7/"

url --url ftp://&lt;username&gt;:&lt;password&gt;@&lt;server&gt;/&lt;dir&gt;

nfs 從指定的NFS伺服器安裝。

nfs --server=nfsserver.example.com --dir=/tmp/install-tree

text 使用文本模式安裝。

lang 設定在安裝過程中使用的語言以及系統的預設語言。lang en_US.UTF-8

keyboard 設定系統鍵盤類型。keyboard us

zerombr 清除mbr引導資訊。

bootloader 系統引導相關配置。

--location=,指定引導記錄被寫入的位置.有效的值如下:mbr(預設),partition(在包含核心的分區的第一個扇區安裝引導裝載程式)或none(不安裝引導裝載程式)。

--driveorder,指定在BIOS引導順序中居首的驅動器。

--append=,指定核心參數.要指定多個參數,使用空格分隔它們。

network 為通過網絡的kickstart安裝以及所安裝的系統配置聯網資訊。

network --bootproto=dhcp --device=eth0 --onboot=yes --noipv6 --hostname=CentOS6

--bootproto=[dhcp/bootp/static]中的一種,預設值是dhcp。bootp和dhcp被認為是相同的。

static方法要求在kickstart檔案裡輸入所有的網絡資訊。

network --bootproto=static --ip=10.0.0.100 --netmask=255.255.255.0 --gateway=10.0.0.2 --nameserver=10.0.0.2

請注意所有配置資訊都必須在一行上指定,不能使用反斜線來換行。

--ip=,要安裝的機器的IP位址.

--gateway=,IP位址格式的預設網關.

--netmask=,安裝的系統的子網路遮罩.

--hostname=,安裝的系統的主機名.

--onboot=,是否在引導時啟用該裝置.

--noipv6=,禁用此裝置的IPv6.

--nameserver=,配置dns解析.

timezone 設定系統時區。timezone --utc Asia/Shanghai

authconfig 系統認證資訊。authconfig --enableshadow --passalgo=sha512

設定密碼加密方式為sha512 啟用shadow檔案。

rootpw root密碼

clearpart 清空分區。clearpart --all --initlabel

--all 從系統中清除所有分區,--initlable 初始化磁盤标簽

part 磁盤分區。

part /boot --fstype=ext4 --asprimary --size=200

part swap --size=1024

part / --fstype=ext4 --grow --asprimary --size=200

--fstype=,為分區設定檔案系統類型.有效的類型為ext2,ext3,swap和vfat。

--asprimary,強迫把分區配置設定為主分區,否則提示分區失敗。

--size=,以MB為機關的分區最小值.在此處指定一個整數值,如500.不要在數字後面加MB。

--grow,告訴分區使用所有可用空間(若有),或使用設定的最大值。

firstboot 負責協助配置redhat一些重要的資訊。

firstboot --disable

selinux 關閉selinux。selinux --disabled

firewall 關閉防火牆。firewall --disabled

logging 設定日志級别。logging --level=info

reboot 設定安裝完成後重新開機,此選項必須存在,不然kickstart顯示一條消息,并等待使用者按任意鍵後才重新開機,也可以選擇halt關機。

編寫ks.cfg檔案

[root@m01 ~]# grub-crypt

Password:

Retype password:

$6$QWtrdZSfLPK6JMvB$/2.tLsLBb59StIJrPxpXkk3zSgzkKMTrvw8tnBNLKxnMEzkjrbNMhhe2cd0fd2bUi5y1f47gXB1T6gbBHApPX.

[root@m01 ~]# mkdir -p /var/www/html/ks_config

[root@m01 ~]# cd /var/www/html/ks_config/

# Kickstart Configurator for CentOS 6.7 by yao zhang

url --url="http://172.16.1.61/CentOS-6.7/"

text

zerombr

rootpw  --iscrypted $6$QWtrdZSfLPK6JMvB$/2.tLsLBb59StIJrPxpXkk3zSgzkKMTrvw8tnBNLKxnMEzkjrbNMhhe2cd0fd2bUi5y1f47gXB1T6gbBHApPX.

clearpart --all --initlabel

selinux --disabled

firewall --disabled

logging --level=info

reboot

tree

nmap

sysstat

lrzsz

dos2unix

telnet

%post

/bin/sh /tmp/optimization.sh

%end

編輯腳本:(使用的是老師張導的腳本)

[root@m01 ks_config]# vim /var/www/html/ks_config/optimization.sh

#!/bin/bash

. /etc/init.d/functions

Ip=172.16.1.61

Port=80

ConfigDir=ks_config

# Judge Http server is ok?

PortNum=`nmap $Ip  -p $Port 2&gt;/dev/null|grep open|wc -l`

[ $PortNum -lt 1 ] &amp;&amp; {

        echo "Http server is bad!"

        exit 1

# Defined result function

function Msg(){

        if [ $? -eq 0 ];then

          action "$1" /bin/true

        else

          action "$1" /bin/false

        fi

# Defined IP function

function ConfigIP(){

        Suffix=`ifconfig eth0|awk -F "[ .]+" 'NR==2 {print $6}'`

        cat &gt;/etc/sysconfig/network-scripts/ifcfg-eth0 &lt;&lt;-END

        DEVICE=eth0

        TYPE=Ethernet

        ONBOOT=yes

        NM_CONTROLLED=yes

        BOOTPROTO=none

        IPADDR=10.0.0.$Suffix

        PREFIX=24

        GATEWAY=10.0.0.2

        DNS1=10.0.0.2

        DEFROUTE=yes

        IPV4_FAILURE_FATAL=yes

        IPV6INIT=no

        NAME="System eth0"

        END

        Msg "config eth0"

# Defined Yum source Functions

function yum(){

        YumDir=/etc/yum.repos.d

        [ -f "$YumDir/CentOS-Base.repo" ] &amp;&amp; cp $YumDir/CentOS-Base.repo{,.ori}

        Msg "YUM source"

# Defined Hide the system version number Functions

function HideVersion(){

        [ -f "/etc/issue" ] &amp;&amp; &gt;/etc/issue

        Msg "Hide issue"

        [ -f "/etc/issue.net" ] &amp;&amp; &gt; /etc/issue.net

        Msg "Hide issue.net"

# Defined OPEN FILES Functions

function openfiles(){

        [ -f "/etc/security/limits.conf" ] &amp;&amp; {

        echo '*  -  nofile  65535' &gt;&gt; /etc/security/limits.conf

        Msg "open files"

        }

# Defined Kernel parameters Functions

function kernel(){

        KernelDir=/etc

        [ -f "$KernelDir/sysctl.conf" ] &amp;&amp; /bin/mv $KernelDir/sysctl.conf{,.ori}

        Msg "Kernel config"

# Defined System Startup Services Functions

function boot(){

        for oldboy in `chkconfig --list|grep "3:on"|awk '{print $1}'|grep -vE "crond|network|rsyslog|sshd|sysstat"`

          do

           chkconfig $oldboy off

        done

        Msg "BOOT config"

# Defined Time Synchronization Functions

function Time(){

        echo "#time sync by zhangyao at $(date +%F)" &gt;&gt;/var/spool/cron/root

        echo '*/5 * * * * /usr/sbin/ntpdate time.nist.gov &amp;&gt;/dev/null' &gt;&gt;/var/spool/cron/root

        Msg "Time Synchronization"

# Defined main Functions

function main(){

        ConfigIP

        yum

        HideVersion

        openfiles

        kernel

        boot

        Time

main

# rz上傳CentOS-Base.repo、epel.repo、sysctl.conf

編輯優化default檔案

# 最精簡配置

[root@linux-node1 ~]# vim /var/lib/tftpboot/pxelinux.cfg/default

default ks

prompt 0

label ks

  append initrd=initrd.img ks=http://172.16.1.61/ks_config/CentOS-6.7-ks.cfg # 告訴安裝程式ks.cfg檔案在哪裡

# append initrd=initrd.img ks=http://10.0.0.7/ks_config/CentOS-6.7-ks.cfg ksdevice=eth0

# ksdevice=eth0代表當用戶端有多塊網卡的時候,要實作自動化需要設定從eth1安裝,不指定的話,安裝的時候系統會讓你選擇,那就不叫全自動化了。

PXE配置檔案default

由于多個用戶端可以從一個PXE伺服器引導,PXE引導映像使用了一個複雜的配置檔案搜尋方式來查找針對客戶機的配置檔案。如果客戶機的網卡的MAC位址為8F:3H:AA:6B:CC:5D,對應的IP位址為10.0.0.195,那麼客戶機首先嘗試以MAC位址為檔案名比對的配置檔案,如果不存在就以IP位址來查找。根據上述環境針對這台主機要查找的以一個配置檔案就是/tftpboot/pxelinux.cfg/01-8F:3H:AA:6B:CC:5D。如果該檔案不存在,就會根據IP位址來查找配置檔案了,這個算法更複雜些,PXE映像查找會根據IP位址16進制命名的客戶機配置檔案。例如:10.0.0.195對應的16進制的形式為C0A801C3。(可以通過syslinux軟體包提供的gethostip指令将10進制的IP轉換為16進制)

如果C0A801C3檔案不存在,就嘗試查找C0A801C檔案,如果C0A801C也不存在,那麼就嘗試C0A801檔案,依次類推,直到查找C檔案,如果C也不存在的話,那麼最後嘗試default檔案。

總體來說,pxelinux搜尋的檔案的順序是:

/tftpboot/pxelinux.cfg/01-88-99-aa-bb-cc-dd

/tftpboot/pxelinux.cfg/C0A801C3

/tftpboot/pxelinux.cfg/C0A801C

/tftpboot/pxelinux.cfg/C0A801

/tftpboot/pxelinux.cfg/C0A80

/tftpboot/pxelinux.cfg/C0A8

/tftpboot/pxelinux.cfg/C0A

/tftpboot/pxelinux.cfg/C0

/tftpboot/pxelinux.cfg/C

/tftpboot/pxelinux.cfg/default

應用:如果已經從廠商擷取了伺服器MAC位址,就可以差異化定制安裝伺服器了。

本文轉自 kesungang 51CTO部落格,原文連結:http://blog.51cto.com/sgk2011/1794381,如需轉載請自行聯系原作者

下一篇: mysql優化

繼續閱讀