多线程与多进程处理python socket并发

多线程处理Socket并发

server

#!/usr/bin/env python
import socket
import threading

server = socket.socket()
server.bind(('', 9999))
server.listen(5)


def readThread(conn, addr):
    """
    创建一个新的线程,负责和一个客户端通讯
    :param conn:
    :param addr:
    :return:
    """
    while True:
        data = conn.recv(1024)
        if data:
            print('{}:{}'.format(addr, data))
        else:
            print("客户端{}已关闭".format(addr))
            break
    conn.close()


while True:
    print('------主线程,等待客户端连接------')
    conn, addr = server.accept()
    print('创建一个新的线程,和客户端{}通讯'.format(addr))
    # 创建一个子线程,负责消息收发
    client = threading.Thread(target=readThread, args=(conn, addr))
    # 启动线程
    client.start()

client

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import socket

# 创建套接字
s = socket.socket()
# 连接套接字,ip和端口必须是服务器上的
s.connect(('127.0.0.1', 9999))
while True:
    data = input("输入发送消息:")
    if 'q' == data:
        s.close()
        break
    s.send(data.encode())
    # print('接受服务器返回的消息:', s.recv(1024))
# s.close()

多进程处理Socket并发

server

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import socket
import threading
import multiprocessing

server = socket.socket()
server.bind(('', 9999))
server.listen(5)


def readProcess(conn, addr):
    """
    创建一个新的线程,负责和一个客户端通讯
    :param conn:
    :param addr:
    :return:
    """
    while True:
        data = conn.recv(1024)
        if data:
            print('{}:{}'.format(addr, data))
        else:
            print("客户端{}已关闭".format(addr))
            break
    conn.close()


while True:
    print('------主线程,等待客户端连接------')
    conn, addr = server.accept()
    print('创建一个新的进程,和客户端{}通讯'.format(addr))
    # 创建一个子进程
    p = multiprocessing.Process(target=readProcess, args=(conn, addr))
    p.start()

 

参考:https://blog.csdn.net/lianjiaokeji/article/details/83095187

 

你可能感兴趣的:(python,socket)