14.1 几个网络模块
服务端:
import socket
s = socket.socket()
host = socket.gethostname()
port = 8090
s.bind((host,port))
s.listen(5)
while True:
c, addr = s.accept()
print('Got connection from',addr)
c.send(b'Thank you for connecting')
c.close()
客户端:
import socket
s = socket.socket()
host = socket.gethostname()
port = 8090
s.connect((host,port))
print(s.recv(1024))
14.1.2 模块urllib和urllib2
1 打开远程文件
urlopen('http://www.baidu.com/')
- 获取远程副本
urlretrive('http://www.baidu.com/','c:\\baidu.html')
14.1.3 其他模块
14.2 SocketServer及相关的类
#基于SocketServer的及简服务器
from socketserver import TCPServer,StreamRequestHandler
class Handler(StreamRequestHandler):
def handle(self):
addr = self.request.getpeername()
print('Got connection from',addr)
self.wfile.write('Thank you for connecting')
server = TCPServer(('',1234),Handler)
server.serve_forever()
14.3 多个连接
处理多个连接的三种方式:分叉(forking)、线程化和异步I/O。
分叉是一个UNIX术语,对进程分叉就是复制一个进程。
14.3.1 使用SocketServer实现分叉和线程化
14.3.2 使用select和poll实现异步I/O
框架 asyncore / asynchat 和Twisted采取的方法
14.4 Twisted
一个事件驱动的Python网络框架
14.5 小结
- 套接字和模块socket
- urllib和urllib2 :从各种服务器读取和下载数据
- 框架SocketServer:包含一系列同步服务器基类,支持使用分叉、多线程
- select和poll : 异步IO基础函数,位于select模块
- Twisted : 自定义网络应用程序,最佳实践