SocketServer简化了网络做事器的编写。在进行socket创建时,利用SocketServer会大大减少创建的步骤,并且SocketServer利用了select它有4个类:TCPServer,UDPServer,UnixStreamServer,UnixDatagramServer。这4个类是同步进行处理的,其余通过ForkingMixIn和ThreadingMixIn类来支持异步。
利用SocketServer的步骤简介
创建做事器的步骤。首先,你必须创建一个要求处理类,它是BaseRequestHandler的子类并重载其handle()方法。

实例化一个做事器类,传入做事器的地址和要求处理程序类。
末了,调用handlerequest()(一样平常是调用其他事宜循环或者利用select())或serveforever()。
集成ThreadingMixIn类时须要处理非常关闭。daemon_threads指示做事器是否要等待线程终止,假如线程相互独立,必须要设置为True,默认是False。
无论用什么网络协议,做事器类有相同的外部方法和属性。
测试案例
做事器端为一个韶光戳做事器,在吸收到客户端发来的数据后,自动回答。
客户端,等待用户输入,回车后向做事器发送用户输入的内容。
分别在python2.7和python3.6下测试。在启动时须要先启动做事器端,在启动客户端。
python2.7下
做事器端代码为
#coding:utf-8import SocketServerfrom time import ctimeprint(\"大众=====================SocketServer TCP做事器=====================\公众);HOST = '' #主机号为空缺表示可以利用任何可用的地址。PORT = 21567 #端口号ADDR = (HOST, PORT)class MyRequestHandler(SocketServer.StreamRequestHandler): #StreamRequestHandler实现TCP/UDP做事器的做事处理器 def handle(self): #重写吸收相应函数 print('...connect from:', self.client_address) data = self.rfile.readline().strip() print(data) self.wfile.write('[%s] %s' % (ctime(), data))tcpSerSock = SocketServer.TCPServer(ADDR, MyRequestHandler)print('等待连接...')tcpSerSock.serve_forever()
客户端代码为
#coding:utf-8from socket import print(\"大众=====================SocketServer TCP客户端=====================\公众);HOST = '127.0.0.1' #本机测试PORT = 21567BUFSIZ = 1024ADDR = (HOST, PORT)while True: tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建客户端套接字 tcpCliSock.connect(ADDR) #发起TCP连接 data = raw_input('> ') #吸收用户输入 if not data: #如果用户输入为空,直接回车就会发送\"大众\公众,\公众\"大众便是代表false break tcpCliSock.send(data+'\n') #客户端发送,必须发送字节数组 data = tcpCliSock.recv(BUFSIZ) #吸收回应,吸收到的是字节数组 if not data: #如果吸收做事器信息失落败,或相应为空 break print(data) #打印回应 tcpCliSock.close() #关闭客户端socket
python3.6下
SocketServer模块在python3中已经更名为socketserver。
做事器端代码为
#coding:utf-8import socketserverfrom time import ctimeprint(\公众=====================SocketServer TCP做事器=====================\公众);HOST = '' #主机号为空缺表示可以利用任何可用的地址。PORT = 21567 #端口号ADDR = (HOST, PORT)class MyRequestHandler(socketserver.StreamRequestHandler): #StreamRequestHandler实现TCP/UDP做事器的做事处理器 def handle(self): #重写吸收相应函数 print('连接到:', self.client_address) data = self.rfile.readline().strip() print(data) self.wfile.write(bytes('[%s] %s' % (ctime(), data.decode('utf-8')),'utf-8'))tcpSerSock = socketserver.TCPServer(ADDR, MyRequestHandler)print('等待连接...')tcpSerSock.serve_forever()
客户端代码为
#coding:utf-8from socket import print(\"大众=====================SocketServer TCP客户端=====================\公众);HOST = '127.0.0.1' #本机测试PORT = 21567BUFSIZ = 1024ADDR = (HOST, PORT)while True: tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建客户端套接字 tcpCliSock.connect(ADDR) #发起TCP连接 data = input('> ') #吸收用户输入 if not data: #如果用户输入为空,直接回车就会发送\"大众\公众,\"大众\公众便是代表false break tcpCliSock.send(bytes(data+'\n','utf-8')) #客户端发送,必须发送字节数组 buffer = tcpCliSock.recv(BUFSIZ) #吸收回应,吸收到的是字节数组 if not buffer: #如果吸收做事器信息失落败,或相应为空 break print(str(buffer,'utf-8')) #打印回应 tcpCliSock.close() #关闭客户端socket做事器类型
5种类型:BaseServer,TCPServer,UnixStreamServer,UDPServer,UnixDatagramServer。把稳:BaseServer不直接对外做事。
做事器工具•class SocketServer.BaseServer:这是模块中的所有做事器工具的超类。它定义了接口,如下所述,但是大多数的方法不实现,在子类中进行细化。
•BaseServer.fileno():返回做事器监听套接字的整数文件描述符。常日用来通报给select.select(), 以许可一个进程监视多个做事器。
•BaseServer.handlerequest():处理单个要求。处理顺序:getrequest(), verifyrequest(), processrequest()。如果用户供应handle()方法抛出非常,将调用做事器的handleerror()方法。如果self.timeout内没有要求收到, 将调用handletimeout()并返回handle_request()。
•BaseServer.serveforever(pollinterval=0.5): 处理要求,直到一个明确的shutdown()要求。每poll_interval秒轮询一次shutdown。忽略self.timeout。如果你须要做周期性的任务,建议放置在其他线程。
•BaseServer.shutdown():见告serve_forever()循环停滞并等待其停滞。python2.6版本。
•BaseServer.addressfamily: 地址家族,比如socket.AFINET和socket.AF_UNIX。
•BaseServer.RequestHandlerClass:用户供应的要求处理类,这个类为每个要求创建实例。
•BaseServer.server_address:做事器侦听的地址。格式根据协议家族地址的各不相同,请参阅socket模块的文档。
•BaseServer.socketSocket:做事器上侦听传入的要求socket工具的做事器。
做事器类支持下面的类变量:
•BaseServer.allowreuseaddress:做事器是否许可地址的重用。默认为false ,并且可在子类中变动。
•BaseServer.requestqueuesize
要求行列步队的大小。如果单个要求须要很长的韶光来处理,做事器忙时要求被放置到行列步队中,最多可以放requestqueuesize个。一旦行列步队已满,来自客户真个要求将得到 “Connection denied”缺点。默认值常日为5 ,但可以被子类覆盖。
•BaseServer.sockettype:做事器利用的套接字类型; socket.SOCKSTREAM和socket.SOCK_DGRAM等。
•BaseServer.timeout:超时时间,以秒为单位,或 None表示没有超时。如果handlerequest()在timeout内没有收到要求,将调用handletimeout()。
下面方法可以被子类重载,它们对做事器工具的外部用户没有影响。
•BaseServer.finish_request():实际处理RequestHandlerClass发起的要求并调用其handle()方法。常用。
•BaseServer.get_request():接管socket要求,并返回二元组包含要用于与客户端通信的新socket工具,以及客户真个地址。
•BaseServer.handleerror(request, clientaddress):如果RequestHandlerClass的handle()方法抛出非常时调用。默认操作是打印traceback到标准输出,并连续处理其他要求。
•BaseServer.handle_timeout():超时处理。默认对付forking做事器是网络退出的子进程状态,threading做事器则什么都不做。
•BaseServer.processrequest(request, clientaddress) :调用finish_request()创建RequestHandlerClass的实例。如果须要,此功能可以创建新的进程或线程来处理要求,ForkingMixIn和ThreadingMixIn类做到这点。常用。
•BaseServer.server_activate():通过做事器的布局函数来激活做事器。默认的行为只是监听做事器套接字。可重载。
•BaseServer.server_bind():通过做事器的布局函数中调用绑定socket到所需的地址。可重载。
•BaseServer.verifyrequest(request, clientaddress):返回一个布尔值,如果该值为True ,则该要求将被处理,反之要求将被谢绝。此功能可以重写来实现对做事器的访问掌握。默认的实现始终返回True。client_address可以限定客户端,比如只处理指定ip区间的要求。常用。
要求处理器
处理器吸收数据并决定如何操作。它卖力在socket层之上实现协议(i.e., HTTP, XML-RPC, or AMQP),读取数据,处理并写反应。可以重载的方法如下:
•setup(): 准备要求处理. 默认什么都不做,StreamRequestHandler中会创建文件类似的工具以读写socket.
•handle(): 处理要求。解析传入的要求,处理数据,并发送相应。默认什么都不做。常用变量:self.request,self.client_address,self.server。
•finish(): 环境清理。默认什么都不做,如果setup产生非常,不会实行finish。
常日只须要重载handle。self.request的类型和数据报或流的做事不同。对付流做事,self.request是socket 工具;对付数据报做事,self.request是字符串和socket 。可以在子类StreamRequestHandler或DatagramRequestHandler中重载,重写setup()和finish() ,并供应self.rfile和self.wfile属性。self.rfile和self.wfile可以读取或写入,以得到要求数据或将数据返回到客户端。
末了,我自己是一名从事了多年开拓的Python老程序员,辞职目前在做自己的Python私人定制课程,今年年初我花了一个月整理了一份最适宜2019年学习的Python学习干货,可以送给每一位喜好Python的小伙伴,想要获取的可以关注我的头条号并在后台私信我:01,即可免费获取。