并发编程——测试socket单线程下使用协程(gevent模块)实现并发效果

gevent模块可以在单线程内启动协程,并且检测到阻塞会自动切换到其他协程,提升效率
测试下服务端单线程内利用协程,客户端开启500个线程连接的效果。

服务端
from gevent import monkey, spawn       # gevent模块下,spawn提交协程
monkey.patch_all()    # 必须放到socket模块之前,放在文件最上,检测识别遇到的阻塞
from socket import *


def communicate(conn):
    while True:
        try:
            data = conn.recv(1024)
            conn.send(data.upper())
        except ConnectionResetError:
            break

    conn.close()


def server(ip, port):
    server = socket(AF_INET, SOCK_STREAM)
    server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
    server.bind((ip, port))
    server.listen(500)

    while True:
        conn, addr = server.accept()
        spawn(communicate, conn)  #创建一个协程对象,第一个参数是函数名,第二个参数是给目标函数传参

    server.close()


if __name__ == '__main__':
    server('127.0.0.1', 8090)  # 放在if __name__ == '__main__':之下

from socket import *
from threading import Thread, currentThread


def client():
    client = socket(AF_INET, SOCK_STREAM)
    client.connect(('127.0.0.1', 8090))

    while True:
        client.send(('%s hello' % currentThread().getName()).encode('utf-8'))
        data = client.recv(1024)
        print(data.decode('utf-8'))

    client.close()


if __name__ == '__main__':
    for i in range(500):  # 开启500个线程
        t = Thread(target=client)
        t.start()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值