cobbler網路裝機

来源:https://www.cnblogs.com/xiaoyafei/archive/2019/01/12/10261056.html
-Advertisement-
Play Games

cobbler網路裝機 原理分析 cobbler簡介 Cobbler通過將設置和管理一個安裝伺服器所涉及的任務集中在一起,從而簡化了系統配置。相當於Cobbler封裝了DHCP、TFTP、XINTED等服務,結合了PXE、kickstart等安裝方法,可以實現自動化安裝操作系統,並且可以同時提供多種 ...


cobbler網路裝機

原理分析

cobbler簡介
Cobbler通過將設置和管理一個安裝伺服器所涉及的任務集中在一起,從而簡化了系統配置。相當於Cobbler封裝了DHCP、TFTP、XINTED等服務,結合了PXE、kickstart等安裝方法,可以實現自動化安裝操作系統,並且可以同時提供多種版本,以實現線上安裝不同版本的系統。

cobbler相關服務

DHCP:DHCP(Dynamic Host Configuration Protocol,動態主機配置協議)是一個區域網的網路協議,使用UDP協議工作, 主要有兩個用途:給內部網路或網路服務供應商自動分配IP地址,給用戶或者內部網路管理員作為對所有電腦作中央管理的手段。DHCP有3個埠,其中UDP67和UDP68為正常的DHCP服務埠,分別作為DHCP Server和DHCP Client的服務埠;546號埠用於DHCPv6 Client,而不用於DHCPv4,是為DHCP failover服務,這是需要特別開啟的服務,DHCP failover是用來做“雙機熱備”的。

TFTP:TFTP是一種比較特殊的文件傳輸協議。相對於FTP和目前經常使用的SFTP,TFTP是基於TCP/IP協議簇,用於進行簡單文件傳輸,提供簡單、低開銷的傳輸服務。TFTP的埠設置為69。
相對於常見的FTP,TFTP有兩個比較好的優勢:

  1. TFTP基於UDP協議,如果環境中沒有TCP協議,是比較合適的;
  2. TFTP執行和代碼占用記憶體量比較小;

預設情況下,Linux內部是安裝了tftp伺服器包的。但是預設是不啟動的。

PXE:預啟動執行環境(Preboot eXecution Environment,PXE,也被稱為預執行環境)提供了一種使用網路介面(Network Interface)啟動電腦的機制。這種機制讓電腦的啟動可以不依賴本地數據存儲設備(如硬碟)或本地已安裝的操作系統。

PXE當初是作為Intel的有線管理體系的一部分,Intel 和 Systemsoft於1999年9月20日公佈其規格(版本2.1)[1]。通過使用像網際協議(IP)、用戶數據報協議(UDP)、動態主機設定協定(DHCP)、小型文件傳輸協議(TFTP)等幾種網路協議和全局唯一標識符(GUID)、通用網路驅動介面(UNDI)、通用唯一識別碼(UUID)的概念並通過對客戶機(通過PXE自檢的電腦)固件擴展預設的API來實現目的。

交互過程

  1. 裸機配置了從網路啟動後,開機後會廣播包請求DHCP伺服器(cobbler server)發送其分配好的一個IP
  2. DHCP伺服器(cobbler server)收到請求後發送responese,包括其ip地址
  3. 裸機拿到ip後再向cobbler server發送請求OS引導文件的請求
    4.cobbler server告訴裸機OS引導文件的名字和TFTP server的ip和port
  4. 裸機通過上面告知的TFTP server地址和port通信,下載引導文件
  5. 裸機執行執行該引導文件,確定載入信息,選擇要安裝的os,期間會再向cobbler server請求kickstart文件和os image
  6. cobbler server發送請求的kickstart和os iamge
  7. 裸機載入kickstart文件
  8. 裸機接收os image,安裝該os image

安裝部署

初始化環境

軟體:vmware workstation 14

操作系統: centos7.4-mini

關閉防火牆:
    systemctl stop firewalld
    systemctl disable firewalld
    
修改selinux:
    sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config 
    
修改網卡配置文件:
    BOOTPROTO=static
    IPV6INIT=no
    ONBOOT=YES
    IPADDR=192.168.26.30
    NETMASK=255.255.255.0
    GATEWAY=192.168.26.2
    DNS1=114.114.114.114
    DNS2=8.8.8.8
    
添加yum源:
    cd /etc/yum.repos.d
    yum -y install epel-release
    yum clean all
    yum makecache
    
最後reboot,保存快照。

安裝需要的包

yum -y install httpd tftp xinetd pykickstart cobbler dhcp
systemctl start httpd cobblerd rsyncd
systemctl enable httpd cobblerd rsyncd

修改配置文件

cobbler主目錄在/etc/cobbler/settings

vim /etc/cobbler/settings
    將server: 127.0.0.1修改為server: 192.168.26.30
    將修改為next_server: 127.0.0.1修改為next_server: 192.168.26.30
    將manage_dhcp: 0修改為manage_dhcp: 1   -->表示由cobbler來控 制dhcp
    :x

修改tftp配置文件:/etc/xinetd.d/tftp
    disabled後面改為no  -->開機啟動
    
cobbler get-loaders  -->下載補丁

修改dhcp:/etc/cobbler/dhcp.template
##此處提出正確配置
subnet 192.168.26.0 netmask 255.255.255.0 {
     option routers             192.168.26.2;
     option domain-name-servers 114.114.114.114;  -->DNS,如果不寫後面在執行安裝後腳本會報錯
     option subnet-mask         255.255.255.0;
     range dynamic-bootp        192.168.26.100 192.168.26.254;
     default-lease-time         21600;
     max-lease-time             43200;
     next-server                $next_server;

設置安裝操作系統的root密碼:
    openssl passwd -1 -salt 'youdaoyun' 'youdaoyun'
    將生成的隨機字元添加到cobbler配置文件中
        將之前這行註釋掉替換成自己的密碼,如下圖

image

重啟應用
    systemctl restart cobblerd xinetd
    cobbler check  -->檢查命令,一般還剩餘兩個,不用管
    cobbler sync  -->同步配置文件

上傳鏡像

選擇的是centos7-mini.iso包,後面有需要的東西可以寫在ks文件中

1.將iso包上傳到根目錄下
    mkdir -p /data/centos7.4-mini
    mount -o loop CentOS-7.4-x86_64-Minimall-1708.iso /data/centos7.4-mini/
    
    使用df -h查看是否掛載成功
    
2.導入鏡像文件
    cobbler import --path=/data/centos7.4-mini/ --name=CentOS_7.4_Mini --arch=x86_64
    
        --path代表鏡像地址
        --name代表當pxe啟動後選擇的哪個鏡像
        --arch代表指定安裝源是64位
    
3.查看profile
    cobbler profile list
    
4.查看profile的內容
    cobbler profile report

5.將已經做好的ks文件修改為centos7_4.cfg上傳到/var/lib/cobbler/kickstarts/,等下會貼出來

6.自定義kickstart文件
cobbler profile edit --name=CentOS_7.4_Mini-x86_64 --kickstart=/var/lib/cobbler/kickstarts/centos7_4.cfg

7.修改centos7內核,即網卡名
cobbler profile edit --name=CentOS_7.4_Mini-x86_64 --kopts='net.ifnames=0 biosdevname=0'

8.修改完配置文件必須運行cobbler sync同步配置

image

ks文件

#Kickstart Configurator for cobbler by Jason Zhao
#platform=x86, AMD64, or Intel EM64T
#System  language
lang en_US
#System keyboard
keyboard us
#Sytem timezone
timezone Asia/Shanghai
#Root password
rootpw --iscrypted $default_password_crypted
#Use text mode install
text
#Install OS instead of upgrade
install
#Use NFS installation Media
url --url=$tree
#System bootloader configuration
bootloader --location=mbr
#Clear the Master Boot Record
zerombr
#Partition clearing information
clearpart --all --initlabel
#Disk partitioning information
part /boot --fstype xfs --size 1024 --ondisk sda
part swap --size 16384 --ondisk sda
part / --fstype xfs --size 1 --grow --ondisk sda
#System authorization infomation
auth  --useshadow  --enablemd5
#Network information
$SNIPPET('network_config')
#network --bootproto=dhcp --device=em1 --onboot=on
# Reboot after installation
reboot
#Firewall configuration
firewall --disabled
#SELinux configuration
selinux --disabled
#Do not configure XWindows
skipx
#Package install information
%pre
$SNIPPET('log_ks_pre')
$SNIPPET('kickstart_start')
$SNIPPET('pre_install_network_config')
# Enable installation monitoring
$SNIPPET('pre_anamon')
%end
 
%post
systemctl disable postfix.service
systemctl stop firewalld
systemctl disable firewalld
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
yum -y install vim net-tools
%end

啟動虛擬機測試
1.設置伺服器網路啟動,在vmware workstation中為按下電源時打開固件
image

2.DHCP獲取過程太快了,直接來到了cobbler的界面
image

選項1為從本地磁碟啟動,但是因為在vmware workstation中做的,預先載入了centos7的環境,所以即使你從本地磁碟啟動,也會是一個安裝操作系統的界面

選項2是我們剛剛做的,直接選擇第二個,然後等待安裝,在安裝完成後會關閉selinux、防火牆,並且安裝vim、net-tools工具包。

其餘配置:有時候需要標識企業信息或者個人信息,可以通過以下方式進行修改。

vim /etc/cobbler/pxe/pxedefault.template
    將第二行的 Cobbler | http://cobbler.github.io/修改成你自己的標識
    
修改完配置文件後需要執行cobbler sync

由於該文檔直接由有道雲筆記拷貝過來,圖像是看不到的,還請見諒。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如下的資料是關於C#從SqlServer資料庫讀寫文件的內容,希望能對碼農們有一些用。 <%@ Page Language="C#" %> <script runat="server"> private string connectionString = "Data Source=192.168.3 ...
  • 很多小伙伴對於【程式發送郵件】不明覺厲的同時又羡慕嫉妒恨,其實發送郵件是一個很常用的功能, 我們這裡就簡單做一個發送郵箱的案例。 PS:案例使用qq郵箱,當然,也可以使用其他郵箱,只要替換郵箱關鍵字即可,下麵案例已做標註。 首先,我們需要一個【當前發件授權碼】,這個碼需要登錄發件箱裡面進行開啟,我們 ...
  • 1、QQ郵箱(mail.qq.com) POP3伺服器地址:pop.qq.com(埠:110) SMTP伺服器地址:smtp.qq.com(埠:25) 2、搜狐郵箱(sohu.com): POP3伺服器地址:pop3.sohu.com(埠:110) SMTP伺服器地址:smtp.sohu.co ...
  • 遞歸調用是一種特殊的嵌套調用,是某個函數調用自己或者是調用其他函數後再次調用自己的,只要函數之間互相調用能產生迴圈的則一定是遞歸調用,遞歸調用一種解決方案,一種是邏輯思想,將一個大工作分為逐漸減小的小工作,比如說一個和尚要搬50塊石頭,他想,只要先搬走49塊,那剩下的一塊就能搬完了,然後考慮那49塊 ...
  • 一.URL 生成 接著上篇講MVC的路由,MVC 應用程式可以使用路由的 URL 生成功能,生成指向操作的 URL 鏈接。 生成 URL 可消除硬編碼 URL,使代碼更穩定、更易維護。 此部分重點介紹 MVC 提供的 URL 生成功能,並且僅涵蓋 URL 生成工作原理的基礎知識。 IUrlHelpe ...
  • 內容來自:https://codereview.stackexchange.com/questions/20871/single-instance-wpf-application 第一步:添加System.RunTime.Remoting引用 第二步:新建一個類class1.cs(按自己想法命名) ...
  • 我們經常花費大量的時間來進行使用瀏覽器搜索網頁,如何進行高效的搜索,需要掌握一些快捷鍵: 使用這些快捷鍵可以,讓游標快速定位到地址欄進行使用預設引擎搜索! 資源來源自網路,保持更新,轉載請註明出處。 ...
  • 今天維護系統時發現一個非常詭異的問題:AAA用戶和BBB用戶同屬AAA組,但用AAA用戶創建的文件,許可權設置為777後,還是不能用BBB用戶刪除。詭異! 幾經周轉,發現AAA用戶創建文件位置的上層目錄的許可權是drwxrwxrwt,做開發這麼多年了,還沒見過所謂"t"的許可權,於是找了一位公司的linu ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...