IP协议及相关技术协议
一、IP基本认识
1. IP的作用
IP在TCP/IP模型中处于网络层,网络层的主要作用是实现主机与主机之间的通信,而IP的作用是在复杂的网络环境中将数据包发送给最终目的主机。
2. IP与MAC的关系
简单而言,MAC的作用是实现“直连”的两个设备之通信,而IP负责“没有直连”的两个网络之间进行通信传输。

源IP和目的IP在传输过程中不会改变,只有源MAC和目的MAC在一直变化。
二、IP地址的基础知识
1. IP地址的分类
总共分为5类,A类、B类、C类、D类、E类。

每类地址中,除去主机号全为1(广播地址)和全为0(用于指定某个网络)的,能够包含的最大主机数量是可以推算的,比如C类:2^8-2 = 254。
广播的分类:
本地广播:发送给192.168.0.255的包不会到达192.168.1.0/24的网络
直接广播:从192.168.0.0网络下的主机发包到192.168.1.255(通常会被路由器认为不安全而屏蔽,无法穿透路由)
组播(多播)地址的作用:
不同于单播(单独发包)、广播(无法穿透路由,不转发广播包),多播用于将同样的包发送给特定组内的所有主机(可穿透路由)。
从224.0.0.0 ~ 239.255.255.255都是多播可用的范围,划分为三类:
· 224.0.0.0 ~ 224.0.0.255为预留的组播地址,只能在局域网中,路由器不进行转发。
· 224.0.1.0 ~ 238.255.255.255为用户可用的组播地址,可用用于Internet上。
· 239.0.0.0 ~ 239.255.255.255为本地管理的组播地址,可供内部网在内部使用,仅在本地范围内有效。
IP分类的优缺点:
优点
通过判断首位为0还是1就可以很快找出网络地址和主机地址。
缺点
(1)同一网络下没有地址层次,比如一个公司用B类地址,可能需要根据生产环境、测试环境、开发环境来划分地址层次,而这种IP分类是没有地址层次划分功能的。
(2)不能很好与现实网络匹配,C类254太少,B类65534又可能太多。
这两个缺点,都可以在CIDR无分类地址解决。
2. 无分类地址CIDR、子网掩码
无分类地址CIDR:
表示形式 a.b.c.d/x,其中 /x 表示前 x 位属于网络号,后面的就是主机号。比如10.100.122.2/24。
子网掩码:
掩码的意思是掩盖掉主机号,剩余的就是网络号,将子网掩码与IP地址按位进行AND运算,就可以的到网络号。
为什么要分离网络号和主机号:
在两台计算机通信时,首先判断是否处于同一个广播域内,即网络地址(网络号)是否相同,如果相同,就可以直接把数据包发送到目的主机。路由器寻址时,也是通过这样的方式来把数据包转发到对应的网络内。
子网划分:
子网掩码除了划分出网络号、主机号,还可以划分子网——把主机地址分为子网网络地址、子网主机地址。如下,划分出四个子网。

3. 公有IP地址、私有IP地址

4. IP地址与路由控制
路由控制表:
IP中网络号这一部分是用于进行路由控制。主机、路由器中的路由控制表记录着网络号与下一步应该发送至的路由器地址。
本地回环:
127.0.0.1作为本地回环地址(localhost),使用时,数据包不会流向网络。
5. IP分片与重组
每种数据链路的最大传输单元都是不同的,如以太网的MTU是1500字节。
当IP数据包大于MTU时,就会被分片,而重组只能由主机完成。
在分片传输中,一旦某个分片丢失,则会造成整个IP数据报作废。TCP引入了MSS在TCP层进行分片,不由IP层分片。而对于UDP,尽量不要发送大于一个MTU的数据报文。
6. IPv6
IPv4是32位的大约可以提供42亿个地址,而IPv6是128位的,可分配地址的数量是很大的。此外IPv6还有更好的安全性和扩展性。
不过IPv4和IPv6之间互不兼容,不但需要设备支持,网络运营商也需要对现有设备升级,所以IPv6普及率比较慢。
亮点:
(1)即使没有DHCP服务器页可自动配置。
(2)头部长度采用固定值40字节,去掉了报头校验和,简化了头部结构,提高了传输的性能。
(3)对伪造IP地址有网络安全功能,能够防止线路窃听,安全性提升。
IPv6地址的标识方法:
16位为一组,用“:”隔开,连续的零可以省略,用“::”隔开。不过,一个IP地址中只能出现一次两个连续的冒号。

单播地址类型:
(1)链路本地单播地址:同一链路单播通信,不经过路由器。
(2)唯一本地地址:在内网里单播通信,相当于IPv4的私有IP。
(3)全局单播地址:在互联网通信,相当于IPv4的公有IP。

7. IPv4头部、IPv6头部

IPv6相比IPv4头部的改进:
(1)取消了首部校验和字段。因为在数据链路层、传输层都会校验,IPv6取消了IP的校验。
(2)取消了分片/重组相关字段。
(3)取消可选字段。这部分的内容出现在,“下一个首部”这个字段。
三、IP协议相关技术
1. DNS域名解析
通常在上网的时候,我们使用的是域名来访问,比如www.server.com。实现这一技术的就是DNS域名解析。DNS中域名使用句点来分隔,越右位置层级越高。

在客户端发出一个DNS请求后,浏览器查看自己的缓存->向操作系统的缓存请求->查询本机域名解析文件hosts->访问本地DNS服务器->根域名服务器->.com顶级域DNS服务器->server.com权威DNS服务器
2. ARP与RARP协议
ARP协议:
主机的路由表可用找到下一跳的IP地址,ARP协议,通过广播ARP请求并获得ARP响应,可以求得下一跳的MAC地址。操作系统通常会缓存这个MAC地址一定时间,以便近期重复使用。

RARP协议:
RARP协议用于已知MAC地址求IP地址。这个过程通常需要一台RARP服务器。硬件设备(主机)发送RARP请求包,从服务器拿到RARP响应来得知自己的IP地址。

3. DHCP动态获取IP地址
分配流程:

四个步骤:
(1)客户端通过UDP广播(不知道DHCP服务器位置)DHCP发现报文(DHCP DISCOVER)的IP数据段,源端口68,目的端口67。
(2)DHCP服务器通过DHCP提供报文(DHCP OFFER)向客户端做出响应,内容包括IP地址、子网掩码、默认网关、DNS服务器、地址租期。
(3)客户端收到一个或多个服务器的OFFER后,选择一个服务器,给它发送DHCP请求报文(DHCP REQUEST),回显配置的参数。
(4)服务端用DHCP ACK报文响应。
IP租约处理:
当DHCP IP地址快到期后,客户端会向服务器发送DHCP请求报文,
(1)如果服务器同意继续使用,则用DHCP ACK应答,客户端延长租期;
(2)如果不让继续,则DHCP NACK,客户端就要停用这个IP。
DHCP中继代理:
在DHCP交互过程中,全程都是UDP广播通信,广播不能穿透路由器,那么每个网络都需要一个DHCP服务器吗?
DHCP中继代理,解决了这个问题,使不同网段的IP地址分配也能由一个DHCP服务器统一管理。

4. NAT网络地址转换、NAPT网络地址与端口转换
NAT协议:
IPv4的地址是很紧缺的,通过CIDR无分类地址可以减缓IPv4的消耗速度。而NAT网络地址转换的方法,也缓解了这个问题。
简单而言,NAT就是把私有IP转换为公有IP。而普通的NAT转换并不会减少IPv4地址的消耗。
NAPT协议:
NAPT网络地址与端口转换,这个转换是IP地址+端口号一同转换的,可以减少消耗。

这种转换在TCP连接首次握手SYN时就会由NAT路由器生成转换表,关闭连接FIN的ACK时会被删除。
所存在的问题:
因为NAT/NAPT都依赖于自己的转换表,会有以下问题:
(1)外部无法主动与NAT内部服务器建立连接,因为NAPT转换表没有转换记录;
(2)转换的过程有性能开销;
(3)如果NAT路由器重启,所有的TCP连接都会重置。
两种解决方法:
(1)改用IPv6
(2)NAT穿透技术
客户端主动从NAT设备获取公有IP地址,然后自己建立端口映射条目,然后用这个条目对外通信,就不需要NAT设备来进行转换了。
5. ICMP互联网控制报文协议
Internet Control Message Protocol,主要功能包括:1. 确定IP包是否成功送达,2. 报告发送过程中IP包被废弃的原因,3. 改善网络设置 等。相关的通知消息也是使用IP进行发送

ICMP大致分为两类:

6. IGMP因特网组管理协议
这个协议和组播(多播)有关,是用来管理组的。IGMP工作在主机和最后一跳之间。

IGMP报文向路由器申请加入/退出组播组,主机申请加入到组播组时,路由器就会记录IGMP路由器表,路由器后续就会转发组播包到对应的主机了。
IGMP报文采用IP封装,IP头部的协议号为2,而且TTL字段值通常为1,因为IGMP是工作在主机与连接的路由器之间。
相关文章:
IP协议及相关技术协议
一、IP基本认识 1. IP的作用 IP在TCP/IP模型中处于网络层,网络层的主要作用是实现主机与主机之间的通信,而IP的作用是在复杂的网络环境中将数据包发送给最终目的主机。 2. IP与MAC的关系 简单而言,MAC的作用是实现“直连”的两个设备之通信…...
小红书x-s算法及补环境 单旋转验证码
前言 大家好呀!新的一年,先祝大家新年快乐咯.祝大家逆向,风控都一把过咯. 新年第一篇文章,后续会持续更新哦! 春晚见证了中国经济的新风口,今年春晚互联网企业赞助商就两家,小红书和京东.小红书类似国外的ins,有预感未来小红书会大火,所以写了这篇文章,有需要的加我,联系方式…...
代码检测规范和git提交规范
摘要:之前开发的项目,代码检测和提交规范都是已经配置好的,最近自己新建的项目就记录下相关配置过程。 1. ESlint配置 2013年6月创建开源项目,提供一个插件化的JavaScript代码检测工具,创建项目是生成的eslintrc.js文…...
Elasticsearch:什么是搜索引擎?
搜索引擎定义 搜索引擎是一种软件程序或系统,旨在帮助用户查找存储在互联网或特定数据库中的信息。 搜索引擎的工作原理是对各种来源的内容进行索引和编目,然后根据用户的搜索查询向用户提供相关结果列表。 搜索引擎对于希望快速有效地查找特定信息的用…...
人工智能几个关键节点:深蓝,AlphaGo,ChatGPT,Sora
近30年,人工智能几个关键节点:深蓝,AlphaGo,ChatGPT,Sora 深蓝: 1997年,深蓝击败卡斯帕罗夫的比赛是通过一系列复杂的算法和策略实现的。深蓝的开发团队使用了一种名为“暴力搜索”的技术&…...
WordPres Bricks Builder 前台RCE漏洞复现(CVE-2024-25600)
0x01 产品简介 Bricks Builder是一款用于WordPress的开发主题,提供直观的拖放界面,用于设计和构建WordPress网站。它使用户能够轻松创建自定义的网页布局和设计,无需编写或了解复杂的代码。Bricks Builder具有用户友好的界面和强大的功能,使用户可以通过简单的拖放操作添加…...
代码随想录算法训练营总结 | 慢慢总结,想起啥就先写上
二叉树总结 二叉树的结构 stauct TreeNode {int val;TreeNode* left;TreeNode* right; }二叉树的递归函数分析 二叉树的递归函数当做只有一个根节点,一个左子树,一个右节点的数去看,这看着是个废话, 其实很重要 回溯…...
基于开源模型对文本和音频进行情感分析
应用场景 从商品详情页爬取商品评论,对其做舆情分析;电话客服,对音频进行分析,做舆情分析; 通过开发相应的服务接口,进一步工程化; 模型选用 文本,选用了通义实验室fine-tune的st…...
SQL中为什么不要使用1=1
最近看几个老项目的SQL条件中使用了11,想想自己也曾经这样写过,略有感触,特别拿出来说道说道。 编写SQL语句就像炒菜,每一种调料的使用都可能会影响菜品的最终味道,每一个SQL条件的加入也可能会影响查询的执行效率。那…...
python 几种常见的音频数据读取、保存方式
1. soundfile 库的使用 soundfile库是一个Python库,主要用于读取和写入音频文件。它支持多种音频格式,包括WAV、AIFF、FLAC和OGG等。通过soundfile库,用户可以方便地将numpy数组存储到音频文件或者将音频文件加载到numpy数组中。此外&#x…...
关于msvcr120.dll丢失怎样修复的详细解决步骤方法分享,msvcr120.dll文件的相关内容
在电脑使用过程中,我们经常遇到各种系统错误,其中msvcr120.dll丢失是一个常见问题。msvcr120.dll文件是Visual C Redistributable for Visual Studio 2015/2017的一个组件,主要用于支持某些应用程序的正常运行。当电脑出现msvcr120.dll丢失情…...
简单几步通过DD工具把云服务器系统Linux改为windows
简单几部通过DD安装其他系统,当服务器的web控制台没有我们要装的系统,就需要通过DD(Linux磁盘)工具来更改系统,(已知支持KVM系统) 本文如何简单的更换系统,不通过web控制台来更换&a…...
使用 package.json 配置代理解决 React 项目中的跨域请求问题
使用 package.json 配置代理解决 React 项目中的跨域请求问题 当我们在开发前端应用时,经常会遇到跨域请求的问题。为了解决这个问题,我们可以通过配置代理来实现在开发环境中向后端服务器发送请求。 在 React 项目中,我们可以使用 package…...
生成 Let‘s Encrypt 免费证书
文章目录 1. 安装 acme.sh2. 添加云服务商安全访问密钥并授权管理DNS记录3. 当前 Shell 添加安全访问密钥变量4. 生成证书5. 拷贝证书6. 清理安全访问密钥变量7. 打开脚本自动更新 代码仓库地址:https://github.com/Neilpang/acme.sh 1. 安装 acme.sh yum -y insta…...
int128的实现(基本完成)
虽然有一个声明叫_int128但是这并不是C标准: long long 不够用?详解 __int128 - FReQuenter - 博客园 (cnblogs.com) 网络上去找int128的另类实现方法,发现几乎都是在介绍_int128的 然后我就自己想了个办法,当时还没学C…...
【linux】使用 acme.sh 实现了 acme 协议生成免费的SSL 证书
acme.sh 实现了 acme 协议, 可以从 letsencrypt 生成免费的证书. 主要步骤: 安装 acme.sh生成证书copy 证书到 nginx/apache 或者其他服务更新证书更新 acme.sh出错怎么办, 如何调试 下面详细介绍. 1. 安装 acme.sh 安装很简单, 一个命令: curl https://get.acme.sh | sh…...
MACOS上面C/C++获取网卡索引,索引获取网卡接口名
依赖函数: if_nametoindex IF名字 to IF索引 if_indextoname IF索引 to IF名字 MACOS 10.7 版本支援(就是2011年发不OSX的第一个面向用的系统版本) int GetInterfaceIndex(const ppp::string& ifrName) noexcept{if (ifrName.empt…...
解决SSH远程登录开饭板出现密码错误问题
输入“adduser Zhanggong回车”,使用adduser命令创建开发板用户名为Zhanggong 输入密码“123456” 输入密码“123456”...
什么时候用ref和reactive
在Vue 3中,ref和reactive都是用于创建响应式数据的工具,但它们的使用场景有所不同。 使用ref的情况: 基本数据类型:当你需要响应式地处理基本数据类型(如数字、字符串、布尔值)时,应该使用ref…...
Java实战:Spring Boot实现邮件发送服务
本文将详细介绍如何在Spring Boot应用程序中实现邮件发送服务。我们将探讨Spring Boot集成邮件发送服务的基本概念,以及如何使用Spring Boot和第三方邮件服务提供商来实现邮件发送。此外,我们将通过具体的示例来展示如何在Spring Boot中配置和使用邮件发…...
web vue 项目 Docker化部署
Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage):…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
Python+ZeroMQ实战:智能车辆状态监控与模拟模式自动切换
目录 关键点 技术实现1 技术实现2 摘要: 本文将介绍如何利用Python和ZeroMQ消息队列构建一个智能车辆状态监控系统。系统能够根据时间策略自动切换驾驶模式(自动驾驶、人工驾驶、远程驾驶、主动安全),并通过实时消息推送更新车…...
计算机基础知识解析:从应用到架构的全面拆解
目录 前言 1、 计算机的应用领域:无处不在的数字助手 2、 计算机的进化史:从算盘到量子计算 3、计算机的分类:不止 “台式机和笔记本” 4、计算机的组件:硬件与软件的协同 4.1 硬件:五大核心部件 4.2 软件&#…...
TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?
在工业自动化持续演进的今天,通信网络的角色正变得愈发关键。 2025年6月6日,为期三天的华南国际工业博览会在深圳国际会展中心(宝安)圆满落幕。作为国内工业通信领域的技术型企业,光路科技(Fiberroad&…...
掌握 HTTP 请求:理解 cURL GET 语法
cURL 是一个强大的命令行工具,用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中,cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...
android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...
什么是VR全景技术
VR全景技术,全称为虚拟现实全景技术,是通过计算机图像模拟生成三维空间中的虚拟世界,使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验,结合图文、3D、音视频等多媒体元素…...
