P2P(Peer to Peer 即对等网络)就是在这种背景下提出的一种网络技术,P2P可以简单地定义为通过直接交换信息,共享计算机资源和服务,对等计算机兼有客户机和服务器的功能。在这种网络中所有的节点是对等的(称为对等点),各节点具有相同的责任与能力并协同完成任务,对等点之间通过直接互连实现信息资源、处理器资源、存储资源甚至高速缓存资源等的全面共享,无需依赖集中式服务器支持。
随着宽带网可使大家在互联网上共享到平时用普通方式难以接触到的各种各样海量的资源。使用P2P软件的每一台PC 都是客户机在下载资源,也是服务器在上传文件,在索取的同时也给予。
BT相信大家都知道了。解释一下BitTorrent是一个多点下载的开放源码的P2P软件,使用的盛行,传统的HTTP和FTP这种一点对多点的下载方式已经满足不了大家的需求了。它会随着下载人数增加而出现连接不上和速度骤减的现象。而P2P技术则打破常规格式,极大地节省了网络带宽。可使你直接连接其他用户的计算机,交换和搜索文件,而不用再通过网页浏览与下载,最大限度地利用了网络带宽。它非常方便。是一个多点下载的共享文件软件,由于在下载的同时,也可为其他用户提供上传,所以不会随着用户人数的增加而降低下载速度,因此,下载的人越多,速度便越快。现在不少大公司如RedHat,都有使用BT让他们的客户下载开发版本。
Linux下的P2P协议主要包括:BitTorrent、aMule、Gnutella等。本文以普遍使用的BitTorrent为例介绍使用P2P服务的方法。
1、搭建BitTorrent服务器
BitTorrent使用Python语言编写,是一个开放源代码软件,既可以在Windows下运行,也可以在Linux环境下运行,目前在Linux下的最新版本是6.1.2。
BitTorrent的官方网址:http://bitconjurer.org/BitTorrent/
安装BitTorrent软件
由于该软件采用Python编写,所以安装BitTorrent前需要使用命令:#rpm -qa|grep Python
检查是否配置了Python语言。否则需要到Python的官方网站http://www.python.org下载安装,然后执行如下命令对BitTorrent软件进行安装:#rpm -ivh BitTorrent-6.1.2.Python2.4.noarch.rpm
安装完成后所有BitTorrent命令和工具都安装在/usr/bin目录下。包括:btmaketorrent.py(制作种子工具)、bttest.py(测试种子工具)、bttrack.py(制作Tracker工具)、btdownloadheadless.py(制作共享源工具)、btlaunchmany.py(后台启动共享源工具)、btshowmetainfo.py(查看下载情况工具)、btdownloadgui.py(图形化制作共享源工具)、btmaketorrent.py(图形化制作种子工具)。
配置和启动BitTorrent
BitTorrent的核心是Tracker,BitTorrent服务不需要服务器,但是BitTorrent服务中仍然有服务器的概念,这里称作Tracker。准确地说,Tracker是指运行的服务器上的一个程序,这个程序可以跟踪多少人同时在下载同一个文件。BT客户端连接到Tracker时会产生一个下载人员名单,根据这个名单,BT客户端会自动连接网络中其他节点进行下载。所以第一步要启动一个Tracker:# ./bttrack.py --port 8760 --dfile dstate > /dev/null 2>&1 &
推荐使用普通用户权限来启动这个服务,这样更加安全。这个命令会在当前目录生成一个dstate的文件,并打开8760端口。
制作种子(Seed)
BT服务器的track服务并不提供下载服务,提供下载的是它的种子(seed),就是一个已经下载完成或正在下载的客户端。因为一开始没有这样的种子,所以你得先自己生成一个,如果要为/home/cjh.avi制作种子,相关命令是:# ./btdownloadheadless.py --max_allow_in 200 --max_upload_rate 100 --minport 8888 --m
相关参数说明如下:
--max_allow 200:指明这个种子最多可以接受200个连接。
--max_upload_rate 100:指这个种子最大的可以接受下载的带宽100 KB(byte)/s,这样可以控制下载带宽。
--minport 8888 --maxport 8888:设置最大最小监听端口号码,这样写就是说种子只监听8888端口,这样方便在防火墙上开端口。
mp3.vio.torrent:是制作的种子文件名称。
设置Apache服务器
配置Web服务器让种子(.torrent)文件和application/x-bittorrent相关联。不久Apache配置文件:/etc/httpd.conf,加入一行:AddType application/x-bittorrent .torrent
然后,我们需要重新启动Web服务器,并且打开防火墙6888端口: