Linux:DHCP伺服器的搭建

来源:https://www.cnblogs.com/yanlzy/archive/2019/11/23/11918290.html
-Advertisement-
Play Games

瞭解DHCP協議工作原理 DHCP(Dynamic Host Configuration Protocol,動態主機配置協議)提供了動態配置IP地址的功能。在DHCP網路中,客戶端不再需要自行輸入網路參數,而是由DHCP伺服器向客戶端自動分配。 IP地址租用的過程 IP租用請求 IP租用提供 IP租 ...


瞭解DHCP協議工作原理

DHCP(Dynamic Host Configuration Protocol,動態主機配置協議)提供了動態配置IP地址的功能。在DHCP網路中,客戶端不再需要自行輸入網路參數,而是由DHCP伺服器向客戶端自動分配。

IP地址租用的過程

IP租用請求

IP租用提供

IP租用選擇

IP租用確認

獲取IP地址後的處理過程
客戶端重新登錄時的IP處理

DHCP客戶端每次重新登錄網路時,不需要再發送DHCP Discover信息,而是直接發送包含前一次所分配的IP地址的DHCP Request請求信息。

IP地址的續約

DHCP的租約期限一般預設是8天,DHCP客戶端必須在租約過期前對它進行續約。

配置DHCP服務

規劃IP地址段
確定DHCP伺服器應分發給客戶端的IP地址範圍。
192.168.10.0/24
192.168.10.100-192.168.10.200
為客戶端確定正確的子網掩碼
255.255.255.0
總經理專用地址:192.168.10.8(保留地址)
確定DHCP伺服器不應向客戶端分發的所有IP地址。
決定IP地址的租約期限
網關地址:192.168.10.254
DNS伺服器地址:192.168.10.1
dhcp服務的安裝與基本配置
安裝DHCP服務
安裝DHCP服務
執行“yum install dhcp”命令進行安裝,在RHEL6系統中所對應的rpm安裝包為“dhcp.x86_64 12:4.1.1-31.P1.el6”。
    服務名稱:dhcpd
主配置文件:/etc/dhcp/dhcpd.conf 預設設置如圖
      
樣板文件:/usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample

dhcpd.conf配置文件的格式如下:
全局參數
聲明 {
    配置選項/局部參數
    配置選項/局部參數
    ……
}

配置好的dhcpd.conf文件

option domain-name-servers 192.168.80.1  設置DNS伺服器選項,可放在全局部份。
Subnet 192.168.80.0 nemask 255.255.255.0 用於定義作用域
Range 192.168.80.21 192.168.80.254  指定當前作用域中可供分配的IP地址範圍
Option routers 192.168.80.2  指定當前作用域的網關
default-lease-time 86400     預設租約時間,單位為秒
max-lease-time 172800      最大租約時間,一般設置為預設租約時間的2倍
啟動dhcp服務
Service dhcpd start
chconfig --level 35 dhcpd on
windows客戶端的配置與測試
關閉VMWare虛擬網卡的DHCP功能

測試能否租用到IP地址

IP地址的釋放與重新申請
在Windows客戶端有兩條非常重要地與DHCP服務相關的命令:
ipconfig   查看本機的IP基本信息
Ipconfig /all  查看本機的IP詳細信息 
ipconfig /release:釋放已經獲得的IP地址。
ipconfig /renew:重新申請IP地址。
“ipconfig /release”命令可以在IP租約未到期之前,主動將地址釋放掉。而執行“ipconfig /renew”命令可以強制開始地址申請過程,使客戶端重新獲得新的IP地址。
自動專用IP地址
自動專用地址是指169.254.0.0/16網段中的地址,這是一個臨時的備用地址,即如果客戶端未能從DHCP伺服器處申請到IP地址,而且也沒有在“TCP/IP屬性”設置中啟用
“備用配置”時,系統會自動分配一個臨時地址。
保留特定的IP地址
保留IP地址的作用
DHCP伺服器可以保留特定的IP地址給指定的客戶端使用,也就是說,當這個客戶端每次向DHCP伺服器索取IP地址或更新租約時,DHCP伺服器都會給該客戶端分配相同的IP地址。
保留IP地址的配置

Option domain-name-servers 192.168.10.1;
Subnet 192.168.10.0 netmask 255.255.255.0{
   Range 192.168.10.20 192.168.10.254;
   Option routers 192.168.10.2;
   Default-lease-time 86400;
   Max-lease-time 172800;
Host teacher{

     Hardware ethernet 00:0C:29:21:98:D6;
     Fixed-address 192.168.10.100;

}
“host teacher”,指定為其保留IP地址的客戶端名稱,名稱可以隨便設置,如這裡為“teacher”。
“hardware ethernet”,指定客戶端電腦的MAC地址。
“fixed-address”,指定對應的保留IP地址。 了
Linux客戶端配置
配置Linux客戶端的網卡配置文件
配置Linux客戶端的網卡配置文件:vim /etc/sysconfig/network-scripts/ifcfg-eth0
ONBOOT=”yes”
BOOTPROTO=dhcp
重啟網卡
Ifdown eth0
Ifup eth0
查看獲取的IP地址
Ifconfig
多個作用域的配置
ddns-update-style none;
option domain-name-servers 192.168.10.1;

subnet 192.168.10.0 netmask 255.255.255.0 {
  range 168.20.0 netmask 255.255.255.0 {
  range 192.168.10.100 192.168.10.200;
  option domain-name "internal.example.org";
  option routers 192.168.10.1;
  option broadcast-address 192.168.10.255;
  default-lease-time 600;
  max-lease-time 7200;
}
subnet 192.168.20.0 netmask 255.255.255.0 {
  range 168.20.0 netmask 255.255.255.0 {
  range 192.168.20.100 192.168.20.200;
  option domain-name "internal.example.org";
  option routers 192.168.20.1;
  option broadcast-address 192.168.20.255;
  default-lease-time 600;
  max-lease-time 7200;
}
配置超級作用域
什麼是超級作用域呢?將多個作用域組合在一起形成超級作用域
ddns-update-style none;
shared-network test {
subnet 192.168.10.0 netmask 255.255.255.0 {
  range 192.168.10.100 192.168.10.200;
  option domain-name-servers 192.168.10.1;
  option domain-name "internal.example.org";
  option routers 192.168.10.1;
  option broadcast-address 192.168.10.255;
  default-lease-time 600;
  max-lease-time 7200;
}
subnet 192.168.0.0 netmask 255.255.255.0 {
  range 192.168.0.100 192.168.0.200;
  option domain-name-servers 192.168.0.1;
  option domain-name "internal.example.org";
  option routers 192.168.0.1;
  option broadcast-address 192.168.0.255;
  default-lease-time 600;
  max-lease-time 7200;
}
host web {
  hardware ethernet 00:0C:29:9D:EA:33;
  filename "vmunix.passacaglia";
  server-name "toccata.fugue.com";
  Fixed-address 192.168.0.110;
}
host DNS {
  hardware ethernet 00:0C:29:9D:EA:33;
  filename "vmunix.passacaglia";
  server-name "toccata.fugue.com";
  Fixed-address 192.168.0.110;
}
配置DHCP中繼代理伺服器
中繼代理伺服器網卡地址配置
eth0:  192.168.10.2
eth1:  192.168.0.1
在dhcp伺服器上配置靜態路由
ip route add 192.168.0.0/24 via 192.168.10.2
在中繼伺服器上開啟轉發功能:vim /etc/sysctl.conf
修    改:net.ipv4.ip_forward=1
啟用轉發:sysctl -p
在中繼伺服器上安裝dhcp服務
配置主配置文件
Subnet 192.168.10.0 netmask 255.255.255.0{
   Range 192.168.10.20 192.168.10.254;
   Option routers 192.168.10.2;
   Default-lease-time 86400;
   Max-lease-time 172800;
}
Subnet 192.168.20.0 netmask 255.255.255.0{
   Range 192.168.0.20 192.168.20.254;
   Option routers 192.16820.1;
   Default-lease-time 86400;
   Max-lease-time 172800;
}
配置中繼代理
配置中繼代理: vim /etc/sysconfig/dhcrelay
修改:INTERFACES=“eth0 eth1”
     DHCPSERVERS=“192.168.10.1”
重啟服務:service dhcrelay start

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

-Advertisement-
Play Games
更多相關文章
  • 1.添加中科大源 參考https://blog.csdn.net/liyunfu233/article/details/87381017 sudo nano /etc/pacman.conf 在文末添加 [archlinuxcn] SigLevel = Optional TrustedOnly Se ...
  • Ubuntu18.04初始化 1. 更新源: 2. 添加中文輸入法:(Ubuntu18.04版使用fctix+sougoupinyin選詞亂碼) Setting Region & Language Manage Installed Languages Select 在 中添加 3. 安裝Chrome ...
  • 安裝 rpm -ivh package_name (package_name指的是RPM包的文件名) 查詢 1.查詢是否安裝,及安裝版本 rpm -q 已安裝的軟體名(ex:rpm -q docker-engine) rpm -qa |grep 字元串(在已安裝的所有軟體中查詢包含某字元串的軟體版本 ...
  • LNMP環境的搭建 安裝DNS伺服器 安裝DNS服務 DNS的配置 創建正向解析 安裝mysql資料庫 安裝mysql 開啟mysql服務 資料庫安全設置 登陸資料庫測試 資料庫的創建與使用 資料庫的操作 查看資料庫 創建資料庫 選擇資料庫 刪除資料庫 資料庫的備份 資料庫的恢復 創建一個空資料庫存 ...
  • 回到: "Linux系列文章" "Shell系列文章" "Awk系列文章" getline用法詳解 除了可以從標準輸入或非選項型參數所指定的文件中讀取數據,還可以使用getline從其它各種渠道獲取需要處理的數據,它的用法有很多種。 getline的返回值: 如果可以讀取到數據,返回1 如果遇到了E ...
  • LAMP環境的搭建 安裝DNS伺服器 安裝DNS服務 DNS的配置 創建正向解析 安裝apache伺服器 配置YUM源 安裝apache 啟動apache服務 設置httpd服務開機啟動 防火牆設置開啟80/443埠 發佈網站 安裝mysql資料庫 安裝mysql 開啟mysql服務 資料庫安全設 ...
  • 回到: "Linux系列文章" "Shell系列文章" "Awk系列文章" awk數據篩選示例 篩選行 awk運維面試試題 從ifconfig命令的結果中篩選出除了lo網卡外的所有IPv4地址。 ...
  • 搭建nginx網站伺服器 安裝nginx 啟動服務 通過瀏覽器測試 修改nginx配置文件 新建vhost目錄 新建/data目錄 功能變數名稱註冊 重啟服務 關閉防火牆 訪問設置好的功能變數名稱 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...