关于python:多人聊天室-多线程-epoll

32次阅读

共计 1095 个字符,预计需要花费 3 分钟才能阅读完成。

应用多线程毛病很显著,服务器为每个客户开一个线程,每个线程都阻塞期待读
客户端须要两个线程,一个用来读,一个用来写。
epoll 的代码还在钻研中
https://github.com/jwzh222/epoll
能够参考这个
顺便一提 windows 下没有 epoll, 只有 Linux 反对。

import socket
import threading
socket_list = []
s = socket.socket()
s.bind(('127.0.0.1', 8888))
s.listen()
def read_client(s):
    try:
        # 接管客户端的数据
        return s.recv(2048).decode('utf-8')
    except:
        # 若有异样,阐明连贯失败,则删除该 socket
        print(str(addr) + 'Left!')
        socket_list.remove(s)
def socket_target(s):
    try:
        while True:
            content = read_client(s)
            if content is None:
                break
            else:
                print(content)
            # 将一个客户端发送过去的数据播送给其余客户端
                for client in socket_list:
                    client.send((str(addr) + 'say:' + content).encode('utf-8'))
    except:
        print('Error!')
while True:
    conn, addr = s.accept()
    # 每当有客户连贯后,就将其加到 socket 列表中
    socket_list.append(conn)
    print(str(addr) + 'Joined!')
    # 每当有客户连贯后,就启动一个线程为其服务
    threading.Thread(target=socket_target, args=(conn,)).start()
import socket
import threading
s = socket.socket()
s.connect(('10.34.22.166', 8888))

def read_server(s):
    while True:
        # 子线程负责从服务端承受数据并打印
        content = s.recv(2048).decode('utf-8')
        print(content)

threading.Thread(target=read_server, args=(s,)).start()     

while True:
    line = input('')
    if line == 'exit':
        break
 # 主线程负责将用户输出的数据发送到 socket 中
    s.send(line.encode('utf-8'))

正文完
 0