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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...