设为首页 收藏本站
查看: 734|回复: 0

[经验分享] Python: SocketServer模块

[复制链接]

尚未签到

发表于 2018-8-8 08:22:51 | 显示全部楼层 |阅读模式
  在Python3中,本模块为socketserver模块。在Python 2中,本模块为SocketServer模块。所以在用import导入时,要分情况导入,否则会报错。导入的代码如下:
1try:2    import socketserver      #Python 33except ImportError:4    import SocketServer      #Python 2  SocketSerror模块包括许多可以简化TCP、UDP、UNIX域套接字  服务器实现的类。
  一、建立自己的处理程序
  要使用本模块,必须定义一个继承于基类BaseRequestHandler的处理程序类。BaseRequestHandler类的实例h可以实现以下方法:
  1、h.handle()  调用该方法执行实际的请求操作。调用该函数可以不带任何参数,但是几个实例变量包含有用的值。h.request包含请求,h.client_address包含客户端地址,h.server包含调用处理程序的实例。对于TCP之类的数据流服务,h.request属性是套接字对象对于数据报服务,它是包含收到数据的字节字符串。
  2、h.setup()   该方法在handle()之前调用。默认情况下,它不执行任何操作。如果希望服务器实现更多连接设置(如建立SSL连接),可以在这里实现。
  3、h.finish()   调用本方法可以在执行完handle()之后执行清除操作。默认情况下,它不执行任何操作。如果setup()和handle()方法都不生成异常,则无需调用该方法。
  注:
  如果知道应用程序只能操纵面向数据流的连接(如TCP),那么应从StreamRequestHandler继承,而不是BaseRequestHandler。StreamRequestHandler类设置了两个属性,h.wfile是将数据写入客户端的类文件对象,h.rfile是从客户端读取数据的类文件对象。
  如果要编写针对数据包操作的处理程序并将响应持续返回发送方,那么它应当从DatagramRequestHandler继承。它提供的类接口与StramRequestHandler相同。
  二、建立服务器对象
  要使用处理程序(即步骤一中建立的处理程序),必须将其插入到服务器对象。定义了四个基本的服务器类。
  (1)TCPServer(address,handler)    支持使用IPv4的TCP协议的服务器,address是一个(host,port)元组。Handler是BaseRequestHandler或 StreamRequestHandler类的子类的实例。
  (2)UDPServer(address,handler)   支持使用IPv4的UDP协议的服务器,address和handler与TCPServer中类似。
  (3)UnixStreamServer(address,handler)   使用UNIX域套接字实现面向数据流协议的服务器,继承自TCPServer。
  (4)UnixDatagramServer(address,handler)  使用UNIX域套接字实现数据报协议的服务器,继承自UDPServer。
  所有四个服务器类的实例都有以下方法和变量:
  1、s.socket   用于传入请求的套接字对象。
  2、s.sever_address  监听服务器的地址。如元组("127.0.0.1",80)
  3、s.RequestHandlerClass   传递给服务器构造函数并由用户提供的请求处理程序类。
  4、s.serve_forever()  处理无限的请求
  5、s.shutdown()   停止serve_forever()循环
  6、s.fileno()   返回服务器套接字的整数文件描述符。该方法可以有效地通过轮询操作(如select()函数)使用服务器实例。
  三、自定义自己的服务器对象
  服务器往往需要特殊的配置来处理不同的网络地址族、超时期、并发和其他功能,可以通过继承上面四个基本服务器类来自行定义。
  可以通过混合类获得更多服务器功能,这也是通过进程或线程分支添加并发行的方法。为了实现并发性,定义了以下类:
  (1)ForkingMixIn         将UNIX进程分支添加到服务器的混合方法,使用该方法可以让服务器服务多个客户。
  (2)ThreadingMixIn    修改服务器的混合类,可以使用线程服务多个客户端。
  要向服务器添加这些功能,可以使用多重继承,其中首先列出混了类。
  由于并发服务器很常用,为了定义它,SocketServer预定义了以下服务器类:
  (1)ForkingUDPServer(address,handler)
  (2)ForkingTCPServer(address,handler)
  (3)ThreadingUDPServer(address,handler)
  (4)ThreadingTCPServer(address,handler)
  上面有点乱,现总结以下:
  SocketServer模块中的类主要有以下几个:
  1、BaseServer    包含服务器的核心功能与混合类(mix-in)的钩子功能。这个类主要用于派生,不要直接生成这个类的类对象,可以考虑使用TCPServer和UDPServer类。
  2、TCPServer    基本的网络同步TCP服务器
  3、UDPServer    基本的网络同步UDP服务器
  4、ForkingMixIn   实现了核心的进程化功能,用于与服务器类进行混合(mix-in),以提供一些异步特性。不要直接生成这个类的对象。
  5、ThreadingMixIn   实现了核心的线程化功能,用于与服务器类进行混合(mix-in),以提供一些异步特性。不要直接生成这个类的对象。
  6、ForkingTCPServer     ForkingMixIn与TCPServer的组合
  7、ForkingUDPServer    ForkingMixIn与UDPServer的组合
  8、BaseRequestHandler
  9、StreamRequestHandler    TCP请求处理类的一个实现
  10、DataStreamRequestHandler   UDP请求处理类的一个实现
  现在繁杂的事务都已经封装到类中了,直接使用类即可。
  使用SocketServer模块编写的TCP服务器端代码:
01#! /usr/bin/env python02#coding=utf-803"""使用SocketServer来实现简单的TCP服务器"""04from SocketServer import (TCPServer,StreamRequestHandler  as SRH)05from time import ctime06 07class MyRequestHandler(SRH):08    def handle(self):09        print "connected from ",self.client_address10        self.wfile.write("[%s] %s"  %(ctime(),self.rfile.readline()))11 12tcpSer=TCPServer(("",10001),MyRequestHandler)13print "waiting for connection"14tcpSer.serve_forever()  相应的TCP客户端代码:
01#! /usr/bin/env python02#coding=utf-803from socket import *04BUFSIZE=102405#每次都要创建新的连接06while True:07    tcpClient=socket(AF_INET,SOCK_STREAM)08    tcpClient.connect(("localhost",10001))09    data=raw_input(">")10    if not data:11        break12    tcpClient.send("%s\r\n" %data)13    data1=tcpClient.recv(BUFSIZE)14    if not data1:15        break16    print data1.strip()17    tcpClient.close()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-548422-1-1.html 上篇帖子: Python stat 模块 下篇帖子: 第九次课:Python文件操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表