P2P通信基本原理

在数字世界的脉络中,点对点(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.rhkb.cn/news/309994.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DC-5渗透测试复现

DC-5渗透测试复现 目的: 获取最高权限以及5个flag 过程: 信息打点-文件包含漏洞-弹shell- scren-4.0.5提权 环境: 攻击机:kali(192.168.85.136) 靶机:DC_3(192.168.85.134) 复现: 一.信息收集 nma…

DC-2渗透测试复现

DC-2渗透测试复现 目的: 获取最高权限以及5个flag 过程: 信息打点-ssh连接-git提权 环境: 攻击机:kali(192.168.85.136) 靶机:DC_2(192.168.85.132) 复现: 一.信息收集 nmap -sP 192.168.85.0/24 …

element问题总结之el-table使用fixed固定列后滚动条滑动到底部或者最右侧的时候错位问题

el-table使用fixed固定列后滚动条滑动到底部或者最右侧的时候错位 效果图前言解决方案纵向滑动滚动条滑动到底部的错位解决横向滚动条滑动到最右侧的错位解决 效果图 前言 在使用el-table固定行的时候移动滚动条会发现移动到底部或者移动到最右侧的时候会出现表头和内容错位或…

头歌-机器学习 第9次实验 随机森林

第1关:Bagging 任务描述 本关任务:补充 python 代码,完成 BaggingClassifier 类中的 fit 和 predict 函数。请不要修改 Begin-End 段之外的代码。 相关知识 为了完成本关任务,你需要掌握: 什么是 Bagging&#xf…

Day37:LeedCode 738.单调递增的数字 968.监控二叉树 蓝桥杯 翻转

738. 单调递增的数字 当且仅当每个相邻位数上的数字 x 和 y 满足 x < y 时&#xff0c;我们称这个整数是单调递增的。 给定一个整数 n &#xff0c;返回 小于或等于 n 的最大数字&#xff0c;且数字呈 单调递增 。 示例 1: 输入: n 10 输出: 9 思路: 假设这个数是98,…

Nginx健康检查

Nginx健康检查nginx_upstream_check_module nginx健康检查介绍: ​ 主动健康检查&#xff0c;nignx定时主动地去ping后端的服务列表&#xff0c;当发现某服务出现异常时&#xff0c;把该服务从健康列表中移除&#xff0c;当发现某服务恢复时&#xff0c;又能够将该服务加回健…

Offer必备算法26_BFS解决最短路_四道力扣题(由易到难)

目录 ①力扣1926. 迷宫中离入口最近的出口 解析代码 ②力扣433. 最小基因变化 解析代码 ③力扣127. 单词接龙 解析代码 ④力扣675. 为高尔夫比赛砍树 解析代码 本篇完。 ①力扣1926. 迷宫中离入口最近的出口 1926. 迷宫中离入口最近的出口 难度 中等 给你一个 m x …

【简明图文教程】Node.js的下载、安装、环境配置及测试

文章目录 前言下载Node.js安装Node.js配置Node.js配置环境变量测试后言 前言 本教程适用于小白第一次从零开始进行Node.js的下载、安装、环境配置及测试。 如果你之前已经安装过了Node.js或删除掉了Node.js想重新安装&#xff0c;需要先参考以下博客进行处理后&#xff0c;再根…

社交网络与Web3:数字社交的下一阶段

随着信息技术的飞速发展&#xff0c;人们的社交方式也发生了巨大的变化。从最初的互联网聊天室到如今的社交网络平台&#xff0c;我们已经见证了数字社交的不断演变和发展。而随着区块链技术的兴起&#xff0c;Web3时代的到来将为数字社交带来全新的可能性和挑战。本文将探讨社…

milvus各组件的结构体分析

milvus各组件的结构体分析 各组件启动&#xff0c;需要构建各组件的结构体&#xff0c;一共8个。 runComponent(ctx, localMsg, wg, components.NewRootCoord, metrics.RegisterRootCoord) runComponent(ctx, localMsg, wg, components.NewProxy, metrics.RegisterProxy) run…

游戏开发者必看:Perforce Helix Core 的功能特点及游戏开发中的常用工具、典型用例介绍

「不出海&#xff0c;即出局」随着全球化的加速发展&#xff0c;企业出海已成燎原之势。日前&#xff0c;2024 亚马逊云科技出海全球化论坛在深圳成功举办。龙智携手 Perforce 亮相游戏行业展区&#xff0c;展示了Perforce Helix Core如何与主流游戏开发引擎高效集成&#xff0…

Docker安装部署Jenkins并发布NetCore应用

Docker安装Jenkins # 拉取镜像 docker pull jenkins/jenkins # 查看镜像 docker images # 运行jenkins # 8080端口为jenkins Web 界面的默认端口 13152是映射到外部 &#xff1a;前面的是映射外部 # 50000端口为jenkins 的默认代理节点&#xff08;Agent&#xff09;通信端口…

FFmpeg: 自实现ijkplayer播放器--06封装打开和关闭stream

文章目录 流程图stream openstream close流程图 stream open 初始化SDL以允许⾳频输出;初始化帧Frame队列初始化包Packet队列初始化时钟Clock初始化音量创建解复用读取线程read_thread创建视频刷新线程video_refresh_threadint FFPlayer::stream_open(const char

java:多线程解决生产者消费者问题

生产者消费者问题 生产者消费者问题&#xff0c;也称有限缓冲问题&#xff0c;是一个多线程同步问题的经典案例。该问题描述了共享固定大小缓冲区的两种线程——即所谓的“生产者”和“消费者”——在实际运行时会发生的问题。生产者的主要作用是生成一定量的数据放到缓冲区中…

第十三届蓝桥杯省赛大学B组编程题(c++)

D.刷题统计 二分(AC): 注意:二分时右边界 right 的确定 #include<iostream> using namespace std; long long a,b,n; bool check(long long x){long long tx/7;x%7;long long temp0;if(x<5) tempx*a;else temp5*a(x-5)*b;long long cntt*(5*a2*b)temp;return cnt&g…

【网站项目】驾校报名小程序

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【Linux学习笔记】安卓设置内核信息的打印级别

开发环境 开发板&#xff1a;正点原子RK3568开发板安卓版本&#xff1a;11 问题描述 在串口调试过程中经常打印出这样的一些信息 极影响调试&#xff0c;暂时又没什么用&#xff0c;有些时候还不能给它直接关了。尤其是这个信息 healthd: battery l50 v3 t2.6 h2 st3 fc10…

如何使用pytorch进行图像分类

如何使用pytorch进行图像分类https://featurize.cn/notebooks/5a36fa40-490e-4664-bf98-aa5ad7b2fc2f

Unity笔记之Android打包、减小包体之类的问题

打包问题 问题1&#xff1a; 一般大部分问题就是JDK、SDK、NDK之类的问题。现在是其他的问题&#xff0c;之前遇到过&#xff0c;好久没玩android了都忘了。 这试了半天&#xff0c;结果是需要有密钥库。那就给他创建一个填一下就行了 &#xff08;在网上看了半天&#xff…

weblogic oracle数据源配置

在weblogic console中配置jdbc oracle数据源 1. base_domain->Service->DataSources 在Summary of JDBC Data Sources中,点击New, 选择【Generic Data Source】通用数据源。 2. 设置数据源Name和JNDI name 注:设置的JNDI Name是Java AP中连接DB使用的数据源名 JND…