码迷,mamicode.com
首页 > 编程语言 > 详细

python之多并发socket

时间:2017-08-10 10:32:23      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:客户端交互   bin   self   str   sock   防范   客户   _for   highlight   

import socketserver


# socketserver有四个基本的类,后两个不常用,这4个类处理并发请求都是同步的,他们其实不是多线程的,他们只是把socke封装了一下,加了一些方法,这里还没有实现多并发和多线程
#这些方法不适用每个请求都耗费长时间才能完成


# socketserver.TCPServer
# socketserver.UDPServer
# socketserver.UnixStreamServer
# socketserver.UnixDatagramServer
# socketserver.ForkingMixIn
# socketserver.ThreadingMixIn

# ========================================================================================================
# 我们真正要用的下面这4个方法
# 多进程的socketserver
# socketserver.ForkingTCPServer
# socketserver.ForkingUDPServer

#多进程的socketserver
# socketserver.ThreadingTCPServer
# socketserver.ThreadingUDPServer


# ========================================================================================================
#这里我们写一个socketserver
# 1、定义一个类
class MyTcpHandler(socketserver.BaseRequestHandler):
    def handle(self):
        #所有和客户端交互的动作全部要在这里写,默认这里是空白的,且必须写handle这个防范
        print("new conn:",self.client_address)
        data = self.request.recv(1024)
        print("client data:",str(data,encoding="utf-8"))
        self.request.send(data)
if __name__ == ‘__main__‘:

    ip_bind = ("127.0.0.1",9000)
    server = socketserver.ThreadingTCPServer(ip_bind,MyTcpHandler)
    #每次来一个连接,就构建一个实例


    server.serve_forever()
    #让这个server一直运行


#客户端的写法和单进程的时候是一样的

  

python之多并发socket

标签:客户端交互   bin   self   str   sock   防范   客户   _for   highlight   

原文地址:http://www.cnblogs.com/bainianminguo/p/7337210.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!