python 之网络并发(非阻塞IO模型)

Posted mylu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python 之网络并发(非阻塞IO模型)相关的知识,希望对你有一定的参考价值。

实现gevent模块

服务端:

技术图片
from socket import *
import time

s = socket()
s.bind((127.0.0.1,8080))
s.listen(5)
s.setblocking(False)

r_list=[]
w_list=[]
while True:
    try:
        conn, addr = s.accept()
        r_list.append(conn)

    except BlockingIOError:
        # time.sleep(0.05)
        print(可以去干其他的活了)
        print(rlist: ,len(r_list))

        # 收消息
        del_rlist=[]
        for conn in r_list:
            try:
                data=conn.recv(1024)
                if not data:
                    conn.close()
                    del_rlist.append(conn)
                    continue
                # conn.send(data.upper())
                w_list.append((conn,data.upper()))
            except BlockingIOError:
                continue
            except ConnectionResetError:
                conn.close()
                # r_list.remove(conn)
                del_rlist.append(conn)

        # 发消息
        del_wlist=[]
        for item in w_list:
            try:
                conn=item[0]
                res=item[1]
                conn.send(res)
                del_wlist.append(item)
            except BlockingIOError:
                continue
            except ConnectionResetError:
                conn.close()
                del_wlist.append(item)

        # 回收无用连接
        for conn in del_rlist:
            r_list.remove(conn)

        for item in del_wlist:
            w_list.remove(item)
View Code

客户端:

技术图片
from socket import *
import os

client = socket()
client.connect((127.0.0.1, 8080))

while True:
    data=%s say hello %os.getpid()
    client.send(data.encode(utf-8))
    res=client.recv(1024)
    print(res.decode(utf-8))
View Code

 

以上是关于python 之网络并发(非阻塞IO模型)的主要内容,如果未能解决你的问题,请参考以下文章

python并发学习总结

Python并发编程之IO模型

python并发编程之IO模型

网络I/O模型---同步异步阻塞非阻塞之惑

python之并发编程—IO模型

Python并发编程-IO模型-非阻塞IO实现SocketServer