网络技术的飞速发展与迅速普及使其成为数据通信的重要手段,网络规模越来越大,连入网络中的计算设备的数量和种类也越来越多,而这些资源并没有得到充分利用,如果能将这些计算单元的处理器计算能力、磁盘存储能力、网络带宽资源等进行充分利用将会有效缓解目前互联网所面临的一些问题。另一方面,现在的互联网是构建在这样的一个假说上的,即网络用户仅仅想从互联网上下载东西,而不会上载信息。如今这种假设受到了愈来愈强烈的挑战,也促使了对等网络技术蓬勃兴起。
P2P(Peer to Peer 即对等网络)就是在这种背景下提出的一种网络技术,P2P可以简单地定义为通过直接交换信息,共享计算机资源和服务,对等计算机兼有客户机和服务器的功能。在这种网络中所有的节点是对等的(称为对等点),各节点具有相同的责任与能力并协同完成任务,对等点之间通过直接互连实现信息资源、处理器资源、存储资源甚至高速缓存资源等的全面共享,无需依赖集中式服务器支持,消除信息孤岛和资源孤岛。任何一台能上网的机器都可以是一个对等点,甚至计算机上的一个程序都可以成为对等点。P2P网络是一种与传统的C/S或多层服务器网络完全不同的网络体系结构,P2P网络中的对等点是彼此直接通讯的。与目前互连网上比较流行的C/S 计算模型不同的是:P2P 计算模型中不再区别服务器以及客户端,系统中的各个节点是逻辑对等的,系统中的各个节点之间可以直接进行数据通信而不需要通过中间的服务器,可以认为它的任何一端同时具有Client和Server 的功能。一些P2P应用也许在某些时候使用服务器,但P2P计算的总体影响是将网络计算分散,它使真正的分布式计算成为可能。
随着宽带网的盛行,传统的HTTP和FTP这种一点对多点的下载方式已经满足不了大家的需求了。它会随着下载人数增加而出现连接不上和速度骤减的现象。而P2P技术则打破常规格式,极大地节省了网络带宽。可使你直接连接其他用户的计算机,交换和搜索文件,而不用再通过网页浏览与下载,最大限度地利用了网络带宽。它可使大家在互联网上共享到平时用普通方式难以接触到的各种各样海量的资源。使用P2P软件的每一台PC 都是客户机在下载资源,也是服务器在上传文件,在索取的同时也给予。
BitTorrent是一个多点下载的开放源码的P2P软件,使用非常方便。是一个多点下载的共享文件软件,由于在下载的同时,也可为其他用户提供上传,所以不会随着用户人数的增加而降低下载速度,因此,下载的人越多,速度便越快。现在不少大公司如RedHat,都有使用BT让他们的客户下载开发版本。
Linux下的P2P协议主要包括:BitTorrent、aMule、Gnutella等。本文以普遍使用的BitTorrent为例介绍使用P2P服务的方法。
1、搭建BitTorrent服务器
BitTorrent使用Python语言编写,是一个开放源代码软件,既可以在Windows下运行,也可以在Linux环境下运行,目前在Linux下的最新版本是6.1.2。
安装BitTorrent软件
由于该软件采用Python编写,所以安装BitTorrent前需要使用命令:
#rpm -qa|grep Python
#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 --maxport 8888 /home/mp3.vio.torrent http://www.bittorrent.com:8760/annouce
相关参数说明如下:
- --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端口:
将制作的种子放到Web服务器的文档目录中,让用户可以访问,启动一个最原始的共享源。
#iptables -A INPUT -i eth0 -p --dport 6888 -j ACCEPT
#iptables -A OUTPUT -i eth0 -p --dport 6888 -j ACCEPT
#./btdownloadheadless.py http://www.mydomain.com/cjh.avi.torrent
其中http://www.mydomain.com/cjh.avi.torrent是种子的URL地址,这样用户通过浏览器访问 cjh.avi.torrent即可实现Web下载。