• 单线程下实现并发的套接字


    from gevent import monkey;monkey.patch_all()
    from socket import *
    from gevent import spawn #导入spawn之前一定要传入monkey
    #俩个io密集型任务
    def comun(conn):
        while True: # 链接循环
            try:
                data = conn.recv(1024)
                if len(data) == 0: break
                conn.send(data.upper())
            except ConnectionResetError:
                break
        conn.close()
    
    def server(ip,port,backlog=5):
        server=socket(AF_INET,SOCK_STREAM)
        server.bind((ip,port))
        server.listen(backlog)
    
        while True:  # 链接循环
            conn,client_addr= server.accept()
            print(client_addr)
    
            # 通信
            spawn(comun,conn)
    
    if __name__ == '__main__':
        g1=spawn(server,'127.0.0.1',8080)
        g1.join()
    服务端
    from threading import Thread,current_thread  #开线程
    from socket import *
    
    def client():
        client= socket(AF_INET,SOCK_STREAM)
        client.connect(('127.0.0.1',8080))
        n=0
        while True:
            msg='%s say hello %s' %(current_thread().name,n)
            n+=1
            client.send(msg.encode('utf-8'))
            data=client.recv(1024)
            print(data.decode('utf-8'))
    
    if __name__ == '__main__':
        for i in range(500):
            t=Thread(target=client)
            t.start()
    客户端

    实现了在单线程下承受500个并发量

  • 相关阅读:
    Java基础-3y
    对线面试官面试系列-3y
    从零单排学Redis【青铜】
    mock官方文档
    route路由组件传递参数
    axios拦截器与vue代理设置
    Sass使用方法
    Less使用方法
    Vue-cli
    Vue-组件注册
  • 原文地址:https://www.cnblogs.com/zhouhao123/p/11139353.html
Copyright © 2020-2023  润新知