| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 系统运维 -> 计算机网络note_P2P -> 正文阅读 |
|
[系统运维]计算机网络note_P2P |
1、P2P没有(或极少)服务器,利用大量Peer节点相互服务,用户量可以扩展到很多。 举例:文件分发(BitTorrent)、钉钉、流媒体(KanKan)、VoIP(Skype) 2、文件分发时间
2.1、C/S模式服务器分发N个文件的时间 t1:; 客户端接收文件的时间 t2:;???????? 传完N个文件至少需要的时间:max{t1,t2(min)}; 2.2、P2P模式? ? ? 3、非结构化P2P管理3.1、集中式目录当客户端上线时,告知服务器自己的IP地址、内容列表;
? 3.2、泛洪查询 : Gnutella
利用图,一个对等方通常连接(少于)10个节点; ?
那么一开始如何连接到节点呢?
3.3、混合式:KaZaA每个对等方,要么是组长,要么是组员; 在一个组的内部,采用集中式的管理; 在组长和组长之间,采用分布式的管理;
4、BitTorrent4.1、一些概念4.1.1、Torrent(洪流)????????参与一个特定文件分发的所有对等方的集合; 4.1.2、Tracker服务器????????跟踪洪流中参与的节点,收集下载者信息并提供给其他下载者,使下载者相互连接; 4.1.3、.torrent,种子文件.torrent文件本质上是文本文件,包含Tracker信息和文件信息两部分,是被下载文件的“索引”。 Tracker信息:BT下载中用到的Tracker服务器的地址和针对Tracker服务器的设置; 文件信息:把提供下载的文件虚拟分成大小相等的块(如256kB),并把每个块的索引信息和Hash验证码写入种子文件(.torrent)中。 4.1.4、bit map每个Pear都有一个bit map,拥有某个256KB,对应的位标记为1; 定期,所有pear节点泛洪bit map,交换信息之后就知道洪流中资源分布; 4.2、下载过程4.2.1、下载概述Alice先得到相应的.torrent文件,然后打开BT客户端软件,BT客户端首先解析.torrent文件得到Tracker地址,然后连接Tracker服务器。 Tracker服务器回应Alice的请求,提供其他下载者(包括发布者)的IP。 Alice再连接其他下载者,根据.torrent文件,两者分别对方告知已经有的块,然后交换没有的块。
4.2.2、加入洪流后,如何获取资源?Alice一开始加入拥有的资源时0,先随机下载4个块,然后请求稀缺块; 得到稀缺块资源,Alice被请求的概率增加,向别人提供的资源越多,本身下载的速度也越快(一报还一报);
?4.2.3、对于被请求资源方,如何处理请求?并不是对所有的请求,都会提供资源,上载能力是有限的,如果同时提供,速度很慢; 有限疏通策略:跟4个节点建立连接,疏通这4个,再由自己和这4个提供资源,分散资源请求; 如何选择节点?前两个周期,优先选择向自己提供服务的节点;第三个周期随机选择; 5、结构化P2PDHT可以看成一个分布式的P2P数据库,这个数据库由许多(key,value)键值对构成。 通过维护树状或环状的结构来查找资源; (2条消息) 详解P2P技术_训灼说的博客-CSDN博客_p2p协议详解 资料:第二个链接资料很多; P2P通信原理与实现(C++) - 有价值炮灰 - 博客园 (cnblogs.com) P2P技术详解(一):NAT详解——详细原理、P2P简介-网络编程/专项技术区 - 即时通讯开发者社区! (52im.net) |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/15 15:31:36- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |