【计算机网络】P2P文件分发介绍

这篇具有很好参考价值的文章主要介绍了【计算机网络】P2P文件分发介绍。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


考虑一个场景:从单一服务器向大量主机(称为对等方)分发一个大文件。
两种处理方式
客户-服务器文件分发:服务器需要向每个对等方发送该文件的一个副本
P2P文件分发:当服务器上传了文件的一个副本后,各个对等点下载该文件的一部分,然后协助服务器上传自己拥有的文件部分

P2P体系结构的自扩展性

对前面提到的文件分发场景进行简单的定量分析,考虑在两种体系结构下的分发时间(distribution time)
【计算机网络】P2P文件分发介绍,# 计算机网络,学习,笔记,计算机网络
分发时间
所有N个对等方得到该文件的副本所需要的时间
客户-服务器体系结构分析
考虑两个时间

  1. 服务器需要向每个对等方传输该文件,即需要上传NF比特数据,得到 N F u s \frac{NF}{u_s} usNF
  2. 考虑所有对等点的下载文件时间,即需要下载速率最小的对等点下载F比特数据,得到 F d m i n \frac{F}{d_{min}} dminF 其中 d m i n = m i n ( d 1 , d 2 , . . . , d N ) d_{min}=min(d_1, d_2, ..., d_N) dmin=min(d1,d2,...,dN)
    则最终的最小分发时间为
    【计算机网络】P2P文件分发介绍,# 计算机网络,学习,笔记,计算机网络
    对足够大的N,客户-服务器分发时间由NF/u确定。则该分发时间随着对等方的数量N线性增加
    P2P体系结构分析
    考虑3个时间
  3. 服务器需要将待传输的文件上传到P2P网络中,得到 F u s \frac{F}{u_s} usF
  4. 各个对等点在整个过程中都会下载至少F比特数据,得到 F d m i n \frac{F}{d_{min}} dminF 其中 d m i n = m i n ( d 1 , d 2 , . . . , d N ) d_{min}=min(d_1, d_2, ..., d_N) dmin=min(d1,d2,...,dN)
  5. 整体分析这个P2P网络,网络中通过一个服务器加所有对等点总共交付NF比特数据,得到NF/( u s + u 1 + u 2 + . . . + u N u_s+u_1+u_2+...+u_N us+u1+u2+...+uN),其中 u t o t a l = u s + u 1 + u 2 + . . . + u N u_{total}=u_s+u_1+u_2+...+u_N utotal=us+u1+u2+...+uN
    得到最终的最小分发时间
    【计算机网络】P2P文件分发介绍,# 计算机网络,学习,笔记,计算机网络
    P2P体系结构的自扩展性
    假设:F/u=1小时, u s u_s us=10u, d m i n ≥ u s d_{min}≥u_s dminus
    【计算机网络】P2P文件分发介绍,# 计算机网络,学习,笔记,计算机网络

CS体系结构的文件分发时间随着对等点数量的增加呈线性增长,而P2P体系结构由于对等方既下载文件块又上传文件块,其文件分发时间对于任意N总小于1小时

分析:由于 d m i n d_{min} dmin u s u_s us,则F/ d m i n d_{min} dmin 小于F/ u u u;对于 D P 2 P D_{P2P} DP2P的最后一项,分子为NF,分母为Nu+ u s u_s us必然会得到一个小于F/u的结果

BitTorrent协议

一个用于文件分发的P2P协议
BitTorrent基础介绍
洪流(torrent):参与一个特定文件分发的所有对等方的集合
在一个torrent中的对等方之间文件传输单位为等长度的文件块(chunk)
追踪器(tracker):每个torrent都有的节点,追踪当前仍在tracker中的对等点。追踪实现方式为:当一个对等方加入某洪流时,它向追踪器注册自己,并周期性地通知追踪器它仍在该洪流中
实例说明
【计算机网络】P2P文件分发介绍,# 计算机网络,学习,笔记,计算机网络
邻近对等方
一个新的对等方Alice加入torrent向tracker注册,tracker随机选择了50个对等方,将这些对等方的ip地址发给Alice,Alice则尝试与这些对等方建立TCP连接,成功建立TCP连接的对等方称为Alice的“邻近对等方”。
文件分发准备
Alice周期性地通过TCP连接询问每个邻近对等方它们所具有的块列表。最终Alice将得到其所有邻近对等方所有的块列表,为其请求她没有的块做准备。
在任何给定的时刻,Alice将具有块的子集并知道它的邻居具有哪些块
请求哪些块
最稀缺优先(rarest first):向邻近对等方请求副本最少的块,一定程度上实现均衡每个块在洪流中的副本数量
响应哪些请求
对换算法:Alice根据当前能够以最高速率向她提供数据的邻居(疏通),给出其优先权。
Alice持续地测量接收到比特的速率,并确定以最高速率流入的4个邻居作为备选相应集,这四个对等方称为疏通(unchocked)。疏通集每过10s则重新计算并修改。另外,每过30s,Alice将随机选择另一个邻居向其发送chunk。除了这5个对等方,其他的邻近对等方都被阻塞,无法与Alice进行数据传输
对等方能够以趋向于找到彼此的协调的速率上载
随机选择邻居允许新的对等方得到块,避免纯速率匹配将数据传输局限在很小范围内文章来源地址https://www.toymoban.com/news/detail-730303.html

参考资料

  1. James F.Kurose&Keith W.Ross Computer Networking A Top-Down Approach(7th ed) 中文版

到了这里,关于【计算机网络】P2P文件分发介绍的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Java 基础篇】Java网络编程实战:P2P文件共享详解

    Java网络编程是现代软件开发中不可或缺的一部分,因为它允许不同计算机之间的数据传输和通信。在本篇博客中,我们将深入探讨Java中的P2P文件共享,包括什么是P2P文件共享、如何实现它以及一些相关的重要概念。 P2P(Peer-to-Peer)文件共享是一种分布式计算模型,其中每个

    2024年02月07日
    浏览(31)
  • 区块链——p2p网络模型

            通常情况下,一个区块链系统的P2P网络层主要由以下几部分组成。         覆盖网络可以根据其对应覆盖图的性质分为两类: 无结构化覆盖网络 和 结构化覆盖网络 。无结构化覆盖网络通常基于随机图来建立节点随机从覆盖网络中选取节点作为邻居;而结构化覆盖

    2024年04月27日
    浏览(41)
  • P2P 网络,PING程序。

    没有废话,直接上版本号和代码,以及讲解。 crate 版本号 libp2p 0.52.1 tokio 1.30.0 Peer-to-Peer是一种网络技术。一种点对点的通讯技术。没有client-service概念。 在P2P网络中,节点标识被成为PeerId。

    2024年02月12日
    浏览(38)
  • 区块链核心技术-P2P网络

    点对点网络是区块链中核心的技术之一,主要关注的方面是为区块链提供一个稳定的网络结构,用于广播未被打包的交易(交易池中的交易)以及共识过的区块,部分共识算法也需要点对点的网络支撑(如PBFT),另外一个辅助功能,如以太坊的消息网络,也需要点对点网络的

    2023年04月17日
    浏览(50)
  • 分布式系统之P2P,云计算,雾计算

    一.P2P cs构架的问题:负载(If too many users access the server/s at the same time, such architecture can suffer from network overload problem.(slow down, long Queues, carsh)同时太多的用户访问服务器就会影响服务器性能) 定义:计算任务由多个节点协同完成,而不是依赖于一个中心节点或服务器。 每个节

    2024年02月02日
    浏览(35)
  • P2P网络NAT穿透原理(打洞方案)

    NAT技术(Network Address Translation,网络地址转换)是一种把内部网络(简称为内网)私有IP地址转换为外部网络(简称为外网)公共IP地址的技术,它使得一定范围内的多台主机只利用一个公共IP地址连接到外网,可以在很大程度上缓解了公网IP地址紧缺的问题,同时也能防止外

    2024年02月15日
    浏览(38)
  • 【MTK平台】【wpa_supplicant】关于wpa_supplicant_8/src/p2p/p2p.c文件的介绍

    本文主要介绍external/wpa_supplicant_8/src/p2p/p2p.c文件 先看下p2p_find 这个方法 P2P_find 主要用于 P2P(点对点)网络中查找其他对等方的功能。另外可以看到设置P2P模块的状态为 P2P_SEARCH  接着看下P2P模块的状态为 P2P_SEARCH后如何进行进入listen状态  也就是p2p_listen_in_find这个方法 在来

    2024年02月14日
    浏览(35)
  • 网络穿透 P2P 穿透 UDP打洞、TCP打洞 原理

    经常听到 网络穿透 P2P 穿透 UDP打洞、TCP打洞 以前只是 知道网络底层的底层的一些知识 接触过 网络穿透 P2P 穿透 UDP打洞、TCP打洞 现在做个笔记: P2P穿透是一种技术,用于在两个或多个设备之间建立直接的点对点连接,而无需依赖中间服务器进行转发。它可以帮助设备在NA

    2024年02月15日
    浏览(33)
  • 去中心化和p2p网络以及中心化为核心的传统通信

    去中心化 P2P通信及其协议实现去中心化 如大数据文件的分布存储 如视频网站服务器 1.p2p网络: 优点: 缺点: 存储应用: 2.典型案例; IPFS: 分布式协议系统 3.完全去中心化应用:基于p2p的区块链+IPFS 注释:中心化(点对点) 传统通信:PSTN的树状架构 注释:互联网中心化平

    2024年02月10日
    浏览(38)
  • P2P网络应用层多播树的建立及维护的解析

    一、什么是对等网络 P2P P2P一般指对等网络 对等计算(Peer to Peer,简称p2p)可以简单的定义成通过直接交换来共享计算机资源和服务,而对等计算模型应用层形成的网络通常称为对等网络。在P2P网络环境中,成千上万台彼此连接的计算机都处于对等的地位,整个网络一般来说

    2024年02月07日
    浏览(74)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包