Python 單線程下實現多個socket並發




## 客戶端


import socket
import gevent
import threading
import multiprocessing

ip_bind = ('127.0.0.1',8000)
c=socket.socket()
c.connect(ip_bind)

def f(n):
    while True:
        data=str(n)
        c.send(bytes(data,encoding='utf8'))
        data = c.recv(1024)
        print('服務端:',str(data,encoding='utf8'))

    c.close()

x=[]
if __name__ == '__main__':
    v=[]


    #多線程實現並發客戶端
    # u=[]
    # for i in range(100):
    #     p = threading.Thread(target=f, args=[str(i), ])
    #     p.start()
    #     u.append(p)
    #
    # for p in u:
    #     p.join()

    # 多進程實現並發客戶端
    for i in range(100):
        p = multiprocessing.Process(target=f,args=[i,])
        p.start()
        v.append(p)
    for p in v:
        p.join()


## 服務端


import  sys
import time
import gevent
from gevent import socket
from gevent import monkey

monkey.patch_all()

#類似於Python中的黑魔法,把很多模塊的阻塞的變成非阻塞的,
#比如socket中的rece 和send 都變
#所以,為了不阻塞

def server(port):
    s=socket.socket()
    s.bind(('127.0.0.1',port))
    s.listen(2000)
    while True:
        cli,add=s.accept()
        gevent.spawn(handle_request,cli)

#通過gevent的啟動一個協程,把客戶端的socket對象傳進去


def handle_request(s):
    try:
        while  True:
            data=s.recv(1024)
            print('收到的信息:',str(data,encoding='utf8'))
            s.send(data)

            if not data:
                s.shutdown(socket.SHUT_WR)
                #把和客戶端的這個鏈接銷毀。
    except Exception as ex:
        print(ex)
    finally:
        s.close()


if __name__ == '__main__':
    server(8000)



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM