DHCP动态主机配置协议,简单点说,就是提供了自动获取ip地址的功能,基于四层的UDP协议;

以下描述此协议的整个工作流程:

(1) 客户端发送discovery报文,二三层广播报文,源ip地址全0;

(2)服务器收到discovery报文之后,进行ip地址分配,找到ip地址,并且进行arp探测,当发现

此ip地址空闲之后,组offer报文,发送给客户端,内部包含有ip地址,客户端mac地址,租约时间等信息;

(3)客户端收到offer报文之后,会选择一个(一般是第一个)进行应答,并且发送request报文到服务器,同时也会进行

ARP探测,当发现有ip地址冲突的时候,会发送decline报文到服务器终止使用该ip地址,然后重新发送discovery;

(4)服务器发送ack报文确认地址,客户端收到ack之后,开始使用该ip地址;

---以上流程报文均为广播;

(5)客户端会在租约时间的1/2和3/4时间开始尝试续租该ip地址,成功则继续使用,否则到达租期后

不能继续使用,需要施放该ip地址,并且重新发discovery;

(6)客户端可以发送release报文随时放弃该ip地址的使用;

我们重点说下服务器的一些实现问题:

1. 建立bit数组,在bit数组中将分配出去或者不能够分配的地址进行标记;

比较烂的实现是每次收到discovery请求之后,先随机一个地址,然后每个地址都去lease链表中查找,

看是否这个lease被分配出去;一开始性能还好,但是当分配的地址接近极限的时候,会出现n*n次遍历

的情况,从而大大影响到性能;

使用bit数组保存地址,每次直接以32个的方式遍历数组,找到不是0xffffffff的区间,然后按照bit查找空闲

bit,从而确定空闲地址;最多只需要n/32次遍历;性能将会大大提升;

2.使用最老租约:

某些时候,客户端可能下线的时候并没有通知服务器,这时候如果服务器的地址池已经使用完,可以选择最早

分配出去的的租约ip进行arp探测,如果已经不在使用,则分配该ip地址给新的客户端;此处涉及到的lease链表

的维护,最好保证每次更新或者添加都使用尾插法,这样就保证了直接取第一个节点就一定是最老的租约,缩短

了遍历的时间;

3.arp防冲突:

arp放冲突这里主要是要保存一些正在arp地址的缓存信息,首先可以防止探测同一个ip地址被多次发送arp;

arp防冲突通常会使用一个定时器,如果超时仍然没有发现冲突,则发送offer报文;否则,需要继续查找下

一个可用ip地址,注意下次查找的地址不能是以前探测冲突的,如果冲突需要在bit数组中打标记;

4.offer包文和ack报文对lease的处理:

offer发送时,会产生一个tmplease插入到lease链表,当发送ack的时候才变成正式的lease,即标记已分配;

如果一个offer的ip地址是一个已经存在的地址,会将原有的lease删除,然后重新添加;在某些测试工具的异常

场景下,ip地址已经分配出去,这时候来了discovery,并且没有检测到冲突,因为工具不回复arp,所以会删除

掉lease,发送offer,但是工具发现自己已经有ip地址了,所以不予回应,导致lease被误删了;这会导致ha情况下

某些同步上的异常情况出现;

先简单的写这么多,后面想起来再写,思路有点乱了;

常见协议基础知识总结--DHCP协议的更多相关文章

  1. 常见协议基础知识总结--FTP协议

    FTP协议是一种基于客户端和服务器的文件传输协议,属于应用层协议,基于传输层的TCP协议: FTP主要分成主动模式和被动模式两种传输方式, 方式是相对服务器而言的,服务器主动发起数据连接即主动方式,使 ...

  2. 【RL-TCPnet网络教程】第25章 DHCP动态主机配置协议基础知识

    第25章      DHCP动态主机配置协议基础知识 本章节为大家讲解DHCP(Dynamic Host Configuration Protocol,动态主机配置协议),通过前面章节对TCP和UDP ...

  3. 【RL-TCPnet网络教程】第41章 HTTP超文本传输协议基础知识

    第41章      HTTP超文本传输协议基础知识 本章节为大家讲解HTTP(HyperText Transfer Protocol,超文本传输协议),从本章节开始,正式进入嵌入式Web的设计和学习. ...

  4. 【RL-TCPnet网络教程】第35章 FTP文件传输协议基础知识

    第35章      FTP文件传输协议基础知识 本章节为大家讲解FTP(File Transfer Protocol,文件传输协议)的基础知识,方便后面章节的实战操作. (本章的知识点主要整理自网络) ...

  5. 【RL-TCPnet网络教程】第33章 SMTP简单邮件传输协议基础知识

    第33章      SMTP简单邮件传输协议基础知识 本章节为大家讲解SMTP(Simple Mail Transfer Protocol,简单邮件传输协议)的基础知识,方便后面章节的实战操作. (本 ...

  6. 【RL-TCPnet网络教程】第16章 UDP用户数据报协议基础知识

    第16章      UDP用户数据报协议基础知识 本章节为大家讲解UDP(User Datagram Protocol,用户数据报协议),需要大家对UDP有个基础的认识,方便后面章节UDP实战操作. ...

  7. IOS Socket 01-网络协议基础知识

    1. 网络参考模型 OSI参考模型                                          TCP/IP参考模型 2. 七层简述 1)物理层:主要定义物理设备标准,如网线的接 ...

  8. TCP/IP网络协议基础知识集锦[转]

    引言 本篇属于TCP/IP协议的基础知识,重点介绍了TCP/IP协议簇的内容.作用以及TCP.UDP.IP三种常见网络协议相关的基础知识. 内容 TCP/IP协议簇是由OSI七层模型发展而来的,之所以 ...

  9. JAVA基础知识|TCP/IP协议

    虽然写代码也有一定的年头了,但是对于一些基础概念,还是很模糊.这在后来的学习过程中,带来了很大的痛苦,所以痛定思痛,决心重新学习这些概念.并把自己的理解和查询的资料做一些整合,便于以后查阅! 一.什么 ...

随机推荐

  1. python3 安装win32clipboard 和 win32con 报No matching distribution found for win32con错误

    win32con.win32clipboad不能用pip install 安装,也不能够查找到这个包,原来,这个是pypiwin32的一部分,直接安装pypiwin32就可以了 pip install ...

  2. LLLYYY的数字思维(模拟题)

    链接:https://ac.nowcoder.com/acm/contest/318/G LLLYYY很喜欢写暴力模拟贪心思维.某一天在机房,他突然抛给了队友ppq一 个问题.问题如下: 有一个函数f ...

  3. LeetCode 3——无重复字符的最长子串

    1. 题目 2. 解答 2.1. 方法一 我们从前往后遍历字符串,start 代表最长子串的起始位置,一开始设置为零. 如果没有遇到重复字符,则更新子串的长度,向后遍历. 如果遇到重复字符时,则更新字 ...

  4. 软工实践Beta冲刺(7/7)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 1.界面的修改与完善 展示GitHub当日代码/文档签入记 ...

  5. 图书 Framework 设计指南: 可重用 .NET 库的约定、惯用法和模式 引出资料

    文章:框架设计准则     --微软 地址:https://docs.microsoft.com/zh-cn/dotnet/standard/design-guidelines/index

  6. lintcode-100-删除排序数组中的重复数字

    100-删除排序数组中的重复数字 素只出现一次,并且返回新的数组的长度. 不要使用额外的数组空间,必须在原地没有额外空间的条件下完成. 样例 给出数组A =[1,1,2],你的函数应该返回长度2,此时 ...

  7. Ubuntu如何进入命令模式

    Ctrl+Alt+T 或者Ctrl+Alt+F2~F6进入命命令模式 Ctrl+Alt+F7返回桌面

  8. golang and intellij

    有一个项目,混合了java和go,需要在intellij中安装go的插件. OK,网上的信息简直混乱不堪,两个流派,一个流派就是装插件,一个流派就是编译插件,各种折腾,还是安装不了,谁知柳暗花明又一村 ...

  9. Anaconda使用入门

    简介 Conda是一个开源的包.环境管理器,可以用于在同一个机器上安装不同版本的软件包及其依赖,并能够在不同的环境之间切换 Anaconda包括Conda.Python以及一大堆安装好的工具包,比如: ...

  10. [剑指Offer] 17.树的子结构

    题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) [思路]要查找树A中是否存在和树B结构一样的子树,可以分成两步: 1.第一步在树A中找到和B的根节 ...