P2P通信基本原理

news2025/1/23 13:11:18

在数字世界的脉络中,点对点(P2P)技术如同一条悄无声息的河流,流经信息的每个角落,连接着世界各地的计算机和设备。这种去中心化的网络模型,不仅打破了传统的客户端-服务器架构的界限,还赋予了数据传输一种前所未有的自由和效率。通过P2P,每个参与者既是消费者又是提供者,共同创造出一个强大、灵活且高度可扩展的网络生态系统。这种技术背后的原理和应用范围之广泛,不禁让人对其可能解锁的未来潜能充满期待。从文件共享和分布式计算到加密货币和去中心化金融,P2P技术正在逐步重塑我们的数字经济和社会结构。

本文阅读时间预计30分钟,可以对该技术有一个入门的了解

一、P2P简介

1.1 什么是P2P

P2P即点对点协议。

当A和B通信的时候,最简单的方式如下,A和B之间通过一个服务器转发数据。

在这里插入图片描述

而P2P是这样的,双方直接进行通信

在这里插入图片描述

这种方式能大大减轻服务端的负载,所以特别适合大数据的传输,比如实时音视频聊天、在线视频直播、大文件传输等应用场景。

1.2 P2P原理

P2P 技术的出现,主要是为了解决,两台不同局域网下的设备,无法通过局域网 IP 地址,直连通信的问题。

因为IPV4的地址有限(25亿个),导致很多设备并没有公网的IP地址,而是多个内网地址使用一个公网地址。

家庭中常见的内网地址有:192.168.xx.xx。只知道对方的内网地址,两个设备是无法通信的。

就像两个人如果只说自己住在几幢几单元,而不说自己住在哪个在哪个城市哪个小区,对方是找不到你的。

而服务器是有公网地址的,因此两个人都可以通过公网地址找到服务器,然后通过服务器的中介,两者建立联系。从下图可以看到,IPC的公网地址是209.144.29.01,手机的公网地址是128.105.39.11,要是IPC能知道手机的公网IP地址(反过来也一样),那就能跳过服务器直接与对方相连。这就是P2P的原理。
在这里插入图片描述

1.3 P2P如何实现

简单来说实现P2P比把大象关进冰箱还要简单,只需要两步

  • 获取自身所在的公网地址

  • 将获取到的公网地址和端口告诉对端。

二、NAT

NAT(网络地址转换器),它可以进入数据包的头部,并且对其修改,已达到多个内网公用一个公网地址的目的。

NAT也有两种,一种是Basic NAT,一种是NAPT,Basic NAT基本被淘汰了,这里只关注NAPT,

2.1 NAT的工作

下面用一个简单的例子来说明,这是两个设备Peer A和 Peer B之间的通信
在这里插入图片描述

有一台计算机,叫PeerB,它的内网地址是192.168.1.10,

它的网关是155.12.39.22(应该还有一个内网的IP地址,比如192.168.1.10)

如果Peer B中的某个进程(这个进程创建了一个UDP Socket,这个Socket绑定8888端口)想访问Peer A 117.78.39.135 的9999端口,那么当数据包通过NAT时会发生什么事情呢?

首先NAT会改变这个数据包的原IP地址,改为155.12.39.22。接着NAT会为这个传输创建一个Session(Session是一个抽象的概念,可以理解成两个手机在打电话,虽然是无形的,但是就是建立了一个对话)并且给这个Session分配一个端口,比如54000,然后改变这个数据包的源端口为54000。

所以本来是(192.168.1.10:8888->117.78.39.135:9999)的数据包到了互联网上变为了(155.12.39.22:54000->117.78.39.135:9999)。

一旦NAT创建了Session后,

NAT会记住这个54000端口对应的就是192.168.1.10:8888,

以后从117.78.39.135发送到54000端口上的数据都会转发到192.168.1.10:8888上,

这样来回都打通了,

我们也就可以认为Peer A 和 Peer B之间建立了连接,并且连接后数据不需要经过服务器。

2.1 NAT类型

NAT有很多类型,这里继续刚才的例子,如果PeerA向另外一个Peer C 发消息,会怎么样呢?

有两种情况,

  • NAT又给Session重新分配一个端口号。

  • NAT还使用原来的session1分配的端口号。

如果NAT类型是第一种,我们称为对称型,如果是这种p2p的魔法就很容易失灵,这种情况一般就不走直连了,走服务器转发。

第二种叫锥型。全锥型又分成4种。

全锥型、受限锥型(IP受限)、端口受限锥型(IP+PORT受限)、对称型。

  1. 全锥型:NAT把所有来自相同内部IP地址和端口的请求映射到相同的外部IP地址和端口。任何一个外部主机均可通过该映射发送IP包到该内部主机。在上面的例子中,只要建立了54000的映射,那Peer C 发送到这个端口的数据包,也会转发到PeerA

  2. 受限锥型:NAT把所有来自相同内部IP地址和端口的请求映射到相同的外部IP地址和端口。但是,只有当内部主机先给IP地址为X的外部主机发送IP包,该外部主机才能向该内部主机发送IP包。在上面的例子中,如果PeerA没有PeerC的IP发过消息,那PeerC给PeerA发的消息会被丢弃

  3. 端口受限锥型:端口限制性圆锥与限制性圆锥类似,只是多了端口号的限制,即只有内部主机先向IP地址为X,端口号为P的外部主机发送1个IP包,该外部主机才能够把源端口号为P的IP包发送给该内部主机。端口受限锥形是在受限锥形的基础上加了端口号的限制。

2.2 P2P连接的条件

并不是所有的设备都能建立P2P连接的,要考虑连接双方的NAT类型。

因为不同NAT的类型的严格程度不一样。

这里先介绍不同的NAT类型。

NAT 类型全锥型受限锥型端口受限锥型对称型
全锥型可以可以可以可以
受限锥型可以可以可以可以
端口受限锥型可以可以可以不可以
对称型可以可以不可以不可以

需要根据通信双方NAT的类型采用不同的穿透技术,如STUN(Session Traversal Utilities for NAT)、TURN(Traversal Using Relays around NAT)或ICE(Interactive Connectivity Establishment)来实现不同NAT类型之间的有效连接。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1597565.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

✌粤嵌—2024/3/11—跳跃游戏

代码实现&#xff1a; 方法一&#xff1a;递归记忆化 int path; int used[10000];bool dfs(int *nums, int numsSize) {if (path numsSize - 1) {return true;}for (int i 1; i < nums[path]; i) {if (used[path i]) {continue;}path i;used[path] 1;if (dfs(nums, num…

C++|运算符重载(1)|为什么要进行运算符重载

写在前面 本篇里面的日期类型加法&#xff0c;先不考虑闰年&#xff0c;平年的天数&#xff0c;每月的天数统一按30天算&#xff0c;那么每一年也就是360天 目录 写在前面 定义 基本数据类型 自定义数据类型 成员函数解决相加问题 Date类&#xff0b;整形 下一篇----运…

6、JVM-JVM调优工具与实战

前置启动程序 事先启动一个web应用程序&#xff0c;用jps查看其进程id&#xff0c;接着用各种jdk自带命令优化应用 Jmap 此命令可以用来查看内存信息&#xff0c;实例个数以及占用内存大小 jmap -histo 14660 #查看历史生成的实例 jmap -histo:live 14660 #查看当前存活的实…

康耐视visionpro-CogDistancePointLineTool操作工具详细说明

◆CogDistancePointLineTool:功能说明&#xff1a; 测量点到线的距离 备注&#xff1a;在“Geometry-Measurement”选项中的所有工具都是测量尺寸或角度工具&#xff0c;包括测量线与线的角度、点与线的距离、圆与圆的距离等测量工具&#xff0c;工具使用的方法相似。 ①.打开…

EasyRecovery2024专业免费的电脑数据恢复软件

EasyRecovery数据恢复软件是一款功能强大的数据恢复工具&#xff0c;广泛应用于各种数据丢失场景&#xff0c;帮助用户从不同类型的存储介质中恢复丢失或删除的文件。 该软件支持恢复的数据类型非常广泛&#xff0c;包括但不限于办公文档、图片、音频、视频、电子邮件以及各种…

ArcGIS Server 10.8.1安装

目录 单机部署 ArcGIS Web Adaptor 优点 缺点 ArcGIS Server 使用的端口 ArcGIS GeoAnalytics Server 使用的端口 官方安装文档&#xff1a; ArcGIS Server 系统要求—ArcGIS Enterprise | ArcGIS Enterprise 文档 单机部署 ArcGIS Web Adaptor 在此示例中&#xff0c…

【神经网络与深度学习】Long short-term memory网络(LSTM)

简单介绍 API介绍&#xff1a; nn.LSTM(input_size100, hidden_size10, num_layers1,batch_firstTrue, bidirectionalTrue)inuput_size: embedding_dim hidden_size: 每一层LSTM单元的数量 num_layers: RNN中LSTM的层数 batch_first: True对应[batch_size, seq_len, embedding…

nginx-ingress详解

一、ingress概述 1、概述 Kubernetes是一个拥有强大故障恢复功能的集群&#xff0c;当pod挂掉时&#xff0c;集群会重新创建一个pod出来&#xff0c;但是pod的IP也会随之发生变化&#xff0c;为了应对这种情况&#xff0c;引入了service&#xff0c;通过service的标签匹配&am…

Python Flask Web 框架-API接口开发_4

一、1、安装 Falsk 当前用户安装 pip3 install --user Flask 确认安装成功&#xff1a; 进入python交互模式看下Flask的介绍和版本&#xff1a; $ python3>>> import flask >>> print(flask.__doc__)flask~~~~~A microframework based on Werkzeug. Its …

【Leetcode】代码随想录Day16|二叉树3.0

文章目录 104 二叉树的最大深度559 n叉树的最大深度111 二叉树的最小深度222 完全二叉树的节点个数 104 二叉树的最大深度 递归法&#xff1a;无论是哪一种顺序&#xff0c;标记最大深度 class Solution(object):def depthHelper(self, root, depth):if root:depth 1left_de…

GPT 交互式提示工程

简介&#xff1a;交互式提示工程 人工智能领域&#xff0c;尤其是 GPT&#xff08;生成式预训练变压器&#xff09;等工具&#xff0c;凸显了即时工程的关键作用。 这篇扩展文章深入探讨了如何设计有效的提示&#xff0c;以从 GPT 等 AI 模型中获得出色的响应。 了解即时工程即…

尚硅谷html5+css3(4)浮动

1.浮动的概念 <head><style>.box1 {width: 200px;height: 200px;background-color: orange;/*通过浮动可以使一个元素向其父元素的左侧或右侧移动使用float属性设置子资源的浮动可选值&#xff1a;none默认值&#xff0c;元素不浮动left向左浮动right向右浮动注意…

分布式监控平台---Zabbix

一、Zabbix概述 作为一个运维&#xff0c;需要会使用监控系统查看服务器状态以及网站流量指标&#xff0c;利用监控系统的数据去了解上线发布的结果&#xff0c;和网站的健康状态。 利用一个优秀的监控软件&#xff0c;我们可以&#xff1a; 通过一个友好的界面进行浏览整个…

SETR——Rethinking系列工作,展示使用纯transformer在语义分割任务上是可行的,但需要很强的训练技巧

题目:Rethinking Semantic Segmentation from a Sequence-to-Sequence Perspective with Transformers 作者: 开源:https://fudan-zvg.github.io/SETR 1.研究背景 1.1 为什么要研究这个问题? 自[ 36 ]的开创性工作以来,现有的语义分割模型主要是**基于全卷积网络( FCN )的…

【机器学习300问】69、为什么深层神经网络比浅层要好用?

要回答这个问题&#xff0c;首先得知道神经网络都在计算些什么东西&#xff1f;之前我在迁移学习的文章中稍有提到&#xff0c;跳转链接在下面&#xff1a; 为什么其他任务预训练的模型参数&#xff0c;可以在我这个任务上起作用&#xff1f;http://t.csdnimg.cn/FVAV8 …

go work模块与go mod包管理是的注意事项

如下图所示目录结构 cmd中是服务的包&#xff0c;显然auth,dbtables,pkg都是为cmd服务的。 首先需要需要将auth,dbtables,pkg定义到go.work中&#xff0c;如下&#xff1a; 在这样在各个单独的go mod管理的模块就可以互相调用了。一般情况下这些都是IDE自动进行的&#xff0c;…

js纯前端实现语音播报,朗读功能(2024-04-15)

实现语音播报要有两个原生API 分别是【window.speechSynthesis】【SpeechSynthesisUtterance】 项目代码 // 执行函数 initVoice({text: 项目介绍,vol: 1,rate: 1 })// 函数 export function initVoice(config) {window.speechSynthesis.cancel();//播报前建议调用取消的函数…

CSS使用自己的字体

在项目的根目录下的static文件夹中放置字体文件。在项目中使用这个字体&#xff0c;需要2个步骤。 一. 你需要在全局样式文件中引入它。 假设你的全局样式文件是App.vue或者App.vue中引入的App.scss文件&#xff0c;你可以像这样引入字体文件&#xff1a; font-face {font-fa…

自然语言控制机械臂:ChatGPT与机器人技术的融合创新(下)

引言 在我们的上一篇文章中&#xff0c;我们探索了如何将ChatGPT集成到myCobot 280机械臂中&#xff0c;实现了一个通过自然语言控制机械臂的系统。我们详细介绍了项目的动机、使用的关键技术如ChatGPT和Google的Speech-to-text服务&#xff0c;以及我们是如何通过pymycobot模块…

C++面向对象程序设计 - 类和对象进一步讨论

在C中&#xff0c;关于面向对象程序设计已经讲了很大篇幅&#xff0c;也例举很多案例&#xff0c;此篇将通过一些习题来进一步了解对象、静态成员、指针、引用、友元、类模板等等相关知识。 一、习题一&#xff08;构造函数默认参数&#xff09; 示例代码&#xff1a; #includ…