将socket通信实现多进程

Posted 明王不动心

tags:

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

我们知道,使用TCP协议需要提前建立连接,这样就只能一对一的传输,但是这样感觉十分单一,如果实现一个服务器能同时和多个客户端同信了?

这里就需要用到多线程。

处理的不同之处就在于:每一个接进来的客户都会创建一个新的进程,这样就能够做到互不干扰

#服务端
from  socket import *
from multiprocessing import Process  #导入模块

server = socket(AF_INET,SOCK_STREAM)
server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
server.bind((127.0.0.1,8130))
server.listen(5)

def func(conn,addr):
    while True:
        try:
            ret = conn.recv(1024)
            if not ret:break     #liunx下防止客户端断掉之后依旧发送空值
            print(ret.decode(utf-8))
            conn.send(ret.upper())
        except ConnectionResetError:
            break
if __name__ == "__main__":
    while True:
        conn,addr = server.accept()   #接进来一个,创建一个子进程
        print("收到来自%s的访问,端口号为%s"% (addr[0],addr[1]))
        p = Process(target = func,args = (conn,addr))
        p.start()

客户端(基本没有变化):

#客户端
from socket import *
client = socket(AF_INET,SOCK_STREAM)
client.connect((127.0.0.1,8130))
while True:
    data = input(">>>").strip()
    if len(data) == 0:continue
    client.send(data.encode(utf-8))
    ret = client.recv(1024)
    print(ret.decode(utf-8))

结果:

收到来自127.0.0.1的访问,端口号为56225
rtyu
收到来自127.0.0.1的访问,端口号为56226
fghjk

 

以上是关于将socket通信实现多进程的主要内容,如果未能解决你的问题,请参考以下文章

多进程并发socket通信

进程对象的其他方法守护进程使用多进程实现 socket tcp协议 server端的并发(抢票程序)队列进程之间的通信(IPC)

go语言快速入门 IPC之Socket 9

线程Queue定时器进程池和线程池同步异步

JavaJava Socket 通信演示样例

多进程并发简单socket