阿尔哦覅和 发表于 2017-4-28 10:12:01

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
页: [1]
查看完整版本: python 网络(三、P2P Programming Framework)