并发编程-基于多进程实现并发套接字通信

Posted hexiaorui123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了并发编程-基于多进程实现并发套接字通信相关的知识,希望对你有一定的参考价值。

服务端:

from socket import *
from multiprocessing import Process

def talk(conn):
    while True:
        try:
            data = conn.recv(1024)
            if not data: break
            conn.send(data.upper())
        except ConnectionRefusedError:
            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(5)

    while True:
        conn, client_addr = server.accept()
        p = Process(target=talk,args=(conn,))
        p.start()

    server.close()

if __name__ == __main__:
    server(127.0.0.1,8080)

客户端:

from socket import *

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

while True:
    msg = input(>>:).strip()
    if not msg : continue

    client.send(msg.encode(utf-8))
    data=client.recv(1024)
    print(data.decode(utf-8))

 

以上是关于并发编程-基于多进程实现并发套接字通信的主要内容,如果未能解决你的问题,请参考以下文章

Python - 并发编程

python并发编程之进程池,线程池concurrent.futures

并发编程热身十个性能小面试题

Python:并发编程

python 并发编程 基于gevent模块 协程池 实现并发的套接字通信

并发网络通信-多进程