利用SocketServer模塊來實現網絡客戶端與服務器並發連接非阻塞通信。
首先,先了解下SocketServer模塊中可供使用的類:
BaseServer:包含服務器的核心功能與混合(mix-in)類掛鈎;這個類只用於派生,所以不會生成這個類的實例;可以考慮使用TCPServer和UDPServer。
TCPServer/UDPServer:基本的網絡同步TCP/UDP服務器。
UnixStreamServer/ UnixDatagramServer:基本的基於文件同步TCP/UDP服務器。
ForkingMixIn/ ThreadingMixIn:實現了核心的進程化或線程化的功能;作為混合類,與服務器類一並使用以提供一些異步特性;這個類不會直接實例化。
ForkingTCPServer/ ForkingUDPServer:ForkingMixIn和TCPServer/UDPServer的組合。
BaseRequestHandler:包含處理服務請求的核心功能。這個類只用於派生,所以不會生成這個類的實例可以考慮使用StreamRequestHandler或DatagramRequestHandler。
StreamRequestHandler/ DatagramRequestHandler:用於TCP/UDP服務器的服務處理工具。
下面我們正式進入主題,這里我們采用StreamRequestHandler和ThreadingTCPServer來實現客戶端與服務器並發連接非阻塞socket。
ThreadingTCPServer派生自ThreadingMixIn,主要實現核心的進程化合線程化功能。
StreamRequestHandler主要用於用於TCP/UDP服務器的服務處理工具。
一、創建SocketServerTCP服務端
#創建SocketServerTCP服務器:
import SocketServer
from SocketServer import StreamRequestHandler as SRH
from time import ctime
host = 'xxx.xxx.xxx.xxx'
port = 9999
addr = (host,port)
class Servers(SRH):
def handle(self):
print 'got connection from ',self.client_address
self.wfile.write('connection %s:%s at %s succeed!' % (host,port,ctime()))
while True:
data = self.request.recv(1024)
if not data:
break
print data
print "RECV from ", self.client_address[0]
self.request.send(data)
print 'server is running....'
server = SocketServer.ThreadingTCPServer(addr,Servers)
server.serve_forever()
二、創建SocketServerTCP客戶端
from socket import *
host = 'xxx.xxx.xxx.xxx'
port = 9999
bufsize = 1024
addr = (host,port)
client = socket(AF_INET,SOCK_STREAM)
client.connect(addr)
while True:
data = raw_input()
if not data or data=='exit':
break
client.send('%s\r\n' % data)
data = client.recv(bufsize)
if not data:
break
print data.strip()
client.close()
