专栏首页python3socketserver实现并发

socketserver实现并发

TCP协议的socket一次只能和一个客户端通信, 而socketsever可以时间和多个客户端通信.

socketserver是在socket的基础上进行了一层封装, 它底层还是调用的socket.

我们通过以下代码来看下socketserver如何使用:

import socketserver # 引入模块

class Myserver(socketserver.BaseRequestHandler):    # 定义一个类, 继承socketserver模块中的BaseRequestHandler类

    def handle(self):    #  # 写一个handle方法, 定死的(约束). 必须叫这个方法
        while 1:
            from_client_msg = self.request.recv(1024)  # 接收消息
            print(from_client_msg.decode('utf-8'))
            server_msg = input('服务端说>>>')
            self.request.send(server_msg.encode('utf-8'))   # 发送消息


if __name__ == '__main__':
    ip_port = ('127.0.0.1', 8008)
    server = socketserver.ThreadingTCPServer(ip_port, Myserver)     # 将IP,端口和定义的类传进socketserver.ThreadingTCPServer这个类.实例化一个对象
    server.serve_forever()  # 使用创建的对象调用server.serve_forever()方法. 这个方法的作用是让服务一直开着

socketserver_服务端

import socket

client = socket.socket()
client.connect(('127.0.0.1', 8008))

while 1:
    client_msg = input('请输入>>>')
    client.send(client_msg.encode('utf-8'))
    from_server_msg = client.recv(1024)
    print(from_server_msg.decode('utf-8'))
    if client_msg == "byebye":
        break

client.close()

socketserver_客户端

 简单解释以下什么是ThreadingTCPServer,多线程?

多线程就是我们的服务端通过多条线程同时和多个客户端进行沟通, 每条线程都对应一个客户端.

其实基于TCP的套接字, 关键就是两个循环, 一个连接循环, 一个通信循环

socketserver模块中分为两大类: server类(解决连接问题) 和 request类(解决通信问题)

server类:

request类:

继承关系:

以上面的代码中的代码为例, 分析socketserver源码:

ip_port = ('127.0.0.1', 8008)
server = socketserver.ThreadingTCPServer(ip_port, Myserver)
server.serve_forever()

 查找属性的顺序: ThreadingTCPServer->ThreadingMixIn->TCPServer->BaseServer

  1. 实例化得到server,先找类ThreadingTCPServer的__init__,在TCPServer中找到,进而执行server_bind,server_active
  2. 找server下的serve_forever,在BaseServer中找到,进而执行self._handle_request_noblock(),该方法同样是在BaseServer中
  3. 执行self._handle_request_noblock()进而执行request, client_address = self.get_request()(就是TCPServer中的self.socket.accept()),然后执行self.process_request(request, client_address)
  4. 在ThreadingMixIn中找到process_request,开启多线程应对并发,进而执行process_request_thread,执行self.finish_request(request, client_address)
  5. 上述四部分完成了链接循环,本部分开始进入处理通讯部分,在BaseServer中找到finish_request,触发我们自己定义的类的实例化,去找__init__方法,而我们自己定义的类没有该方法,则去它的父类也就是BaseRequestHandler中找....

 源码分析总结:

基于TCP的socketserver我们自己定义的类中的

  1.   self.server即套接字对象
  2.   self.request即一个链接
  3.   self.client_address即客户端地址

基于udp的socketserver我们自己定义的类中的

1.self.request是一个元组(第一个元素是客户端发来的数据,第二部分是服务端的udp套接字对象).

2.self.client_address即客户端地址

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python32 Socket Serv

    TCPServer继承了BaseServer UnixStreamServer继承了TCPServer

    py3study
  • Python 学习笔记 - socket

    前面学习的例子都是单线程的socket收发;如果有多个用户同时接入,那么除了第一个连入的,后面的都会处于挂起等待的状态,直到当前连接的客户端断开为止。

    py3study
  • wsgi 协议

    本来没打算这么早就学习 wsgi 的,因为想要学习python 是如何处理网络请求的绕不开 wsgi,所以只好先学习一下 wsgi。先对 wsgi 有个印象,到...

    py3study
  • Python32 Socket Serv

    TCPServer继承了BaseServer UnixStreamServer继承了TCPServer

    py3study
  • Python 学习笔记 - socket

    前面学习的例子都是单线程的socket收发;如果有多个用户同时接入,那么除了第一个连入的,后面的都会处于挂起等待的状态,直到当前连接的客户端断开为止。

    py3study
  • 28.Python中对象的特性

    对象的属性有时候是私有的,要想获取这些属性需要通过存取器方法(get和set),我们在用到对象的这些属性的时候需要用提前定义好的set和get函数来操作这些属性...

    用户4381798
  • mqtt 客户端 基于Python

    这几天一直在搞安全通信,微信小程序,反向代理等等,为了能让自己对整个系统做到把控,主要是需要了解每一个细节的地方,所以今天花了3个小时的时间学习了Python,...

    杨奉武
  • Python爬虫基础知识:百度贴吧网络爬虫及源码分享

    糖豆贴心提醒,本文阅读时间6分钟 百度贴吧的爬虫制作和糗百的爬虫制作原理基本相同,都是通过查看源码扣出关键数据,然后将其存储到本地txt文件。 项目内容: ...

    小小科
  • 送你一张selenium全知识思维导图,快来收藏吧!

    简单来说selenium是用于测试web应用的常用测试框架,提供了很丰富的API,支持多种语言编写测试脚本,并且可以在多种浏览器执行测试脚本。

    吾非同
  • [转]红黑树

    先来看下算法导论对R-B Tree的介绍: 红黑树,一种二叉查找树,但在每个结点上增加一个存储位表示结点的颜色,可以是Red或Black。 通过对任何一条从根到...

    DH镔

扫码关注云+社区

领取腾讯云代金券