这篇文章纯粹是对http://cs.berry.edu这个大学的这个计算机的这段p2p框架代码的学习。代码结构灰常简单,逻辑清晰。并且基于这段代码实现了一个p2p文件共享系统。受益颇多。
一、p2p编程框架(及其python实现)
p2p框架代码: btpeer.py
p2p协议实现代码(即P2P文件共享协议): btfiler.py
P2P文件共享系统用户界面:filergui.py
二、
关于这个P2P框架,思考下面的问题:
1. 为啥self.sd = self.s.makefile('rw',0),为何不直接在socket上读写
2. 语法?
try:
...
except KeyboardInterrupt:
raise
except:
if self.debug:
traceback.print_exc()
return False
return True
3. self.sd.read(4):表示最多读取4个byte,若不到4个就少读一点罢了
4. BTPeerConnection::recvdata()中,
data = self.sd.read( min(2048, msglen-len(msg)) )
(1) 2048用意?
(2) self.sd.read(...)表示:最"多"读取的字节数
5. stabilizer的: 定期去ping每个peer, 将死亡的peer从self.peers中移除
(注:self.peerlock需要加锁)
参考文献:
p2p框架参考:
Peer-to-Peer Programming http://cs.berry.edu/~nhamid/p2p/index.html
P2P Programming Framework - Python http://cs.berry.edu/~nhamid/p2p/framework-python.html
File Sharing Application - Python http://cs.berry.edu/~nhamid/p2p/filer-python.html
编程参考:
socket模块 http://docs.python.org/2/library/socket.html
threading模块 http://docs.python.org/2.7/library/threading.html
python实现一个P2P文件发布,这段代码还没看过: http://blog.netzhou.net/?p=252