多进程并发socket通信

Posted zhoajiahao

tags:

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

实现多个客户端同时接入server端,并且可以同时向客户端发送信息

server端

def dunc(conn,client_addr):
    while True:
        data=conn.recv(1024)
        print(data,client_addr)
        if data.decode('utf8')=='nihao':
            conn.send('我一点都不好'.encode('utf8'))
        elif data.decode('utf8')=='chifanma':
            conn.send('去吃什么?'.encode('utf8'))
        else:
            conn.send(data.upper())


if __name__ == '__main__':
    import socket
    from multiprocessing import Process

    server=socket.socket()
    server.bind(('127.0.0.1',8080))
    server.listen()
    print('start...')
    while True:
        conn,client_addr=server.accept()
        p=Process(target=dunc,args=(conn,client_addr))
        p.start()

client端

import socket

client=socket.socket()
client.connect(('127.0.0.1',8080))

while True:
    msg=input('请输入你要发送的信息:')
    if not msg:
        continue
    client.send(msg.encode('utf-8'))
    data=client.recv(1024)
    print(data.decode('utf-8'))

需要注意的是:1. 根据TCP内部算法,发送端发送内容为空的时候,不会发送,但是会往下执行;接收端则会一直卡在recv处;所以需要进行一个是否为空的判断。

  1. 客户端的listen(5),参数(5)的意思是允许的最大半连接数;半连接数的意思是,没有完成TCP的第三次握手;
    产生了半连接的情况:1. 服务器忙不过来,应该提升服务器的性能
    2. 洪水攻击,指的是有许多的客户端处于半连接,没有返回第三次握手信息,占用系统的资源

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

多进程并发简单socket

Linux多进程的应用

socket实现并发和介绍

Socket通信实例(C#)

Socket的通信机制?

将socket通信实现多进程