`

python 网络(三、P2P Programming Framework)

 
阅读更多

       这篇文章纯粹是对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

 

 

  • 大小: 63.6 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics