服务器仅打印来自最近连接的客户端的消息

时间:2019-01-21 03:25:43

标签: python-3.x multithreading sockets

我正在尝试创建一个接受多个客户端的服务器。客户端可以将消息发送到服务器,服务器将打印这些消息。我在下面的代码中产生了一个奇怪的结果,其中只有最新的连接的消息才被服务器接受并打印。

server.py

import socket
import _thread

HOST = "192.168.1.84"
PORT = 5000


def client_thread(conn):
    welcome_message = "Connected to server " + HOST + ":" + str(PORT) + "\n"
    conn.send(welcome_message.encode("ascii"))
    while True:
        data = connection.recv(2048)
        message = data.decode("ascii")
        if not data:
            break
        print("(" + address[0] + ":" + str(address[1]) + ") " + message)
    connection.close()


with socket.socket() as server_socket:
    try:
        server_socket.bind((HOST, PORT))
        server_socket.listen(10)
        print("Server hosted on " + HOST + ":" + str(PORT) + "\n")
        while True:
            connection, address = server_socket.accept()
            _thread.start_new_thread(client_thread, (connection,))
            print("Connection from " + address[0] + ":" + str(address[1]))

    except socket.error as error_message:
        print("Error: " + str(error_message))

client.py

import socket

HOST = "192.168.1.84"
PORT = 5000

with socket.socket() as client_socket:
    try:
        client_socket.connect((HOST, PORT))
        data = client_socket.recv(2048)
        print(data.decode("ascii"))
        while True:
            message = input()
            data = message.encode("ascii")
            client_socket.send(data)
    except socket.error as error_message:
        print("Error: " + str(error_message))

问题输出行为:

客户端1可以连接到服务器并发送消息。服务器可以很好地接收和打印这些消息。

现在,当客户端2连接到服务器时,客户端1的消息不再发送到服务器。现在,只有客户端2可以将消息发送到服务器,并可以正常打印。

要进一步执行此操作,客户端3连接到服务器。现在,客户端1和客户端2的消息都不会发送到服务器,只有客户端3的消息才发送到服务器。

1 个答案:

答案 0 :(得分:0)

您的client_thread函数存在一些问题。 conn是传递给线程的连接,但是正在从全局名称空间读取connectionaddress。相反,请使用传入的连接并同时传递address,因此每个线程仅引用其负责的连接/地址对的局部变量:

def client_thread(conn,addr):
    welcome_message = "Connected to server " + HOST + ":" + str(PORT) + "\n"
    conn.send(welcome_message.encode("ascii"))
    while True:
        data = conn.recv(2048)
        message = data.decode("ascii")
        if not data:
            break
        print("(" + addr[0] + ":" + str(addr[1]) + ") " + message)
    conn.close()

在主代码中:

_thread.start_new_thread(client_thread, (connection,address))