使用池来实现并发服务器

Posted naniandiam

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用池来实现并发服务器相关的知识,希望对你有一定的参考价值。

#使用池来实现并发服务器
import socket
from multiprocessing import cpu_count,Pool
from multiprocessing.pool import ThreadPool

server=socket.socket()
server.bind((‘0.0.0.0‘,8080))
server.listen(1000)


def work_process(server):#处理server的进程
    thread_pool=ThreadPool(cpu_count())  #如果不想用线程池的话,可以直接用普通线程
    while True:
        connection,remote_address=server.accept()
        thread_pool.apply_async(worker_thread,args=(connection,))
def worker_thread(connection):
    while True:
        recv_data=connection.recv(1000)
        if recv_data:
            print(recv_data.decode(‘utf-8‘))
            connection.send(recv_data)
        else:
            connection.close()
            break
n=cpu_count() #获取cpu个数
pool=Pool(n)
for i in range(2):
    pool.apply_async(work_process,args=(server,))
pool.close()
pool.join()

以上是关于使用池来实现并发服务器的主要内容,如果未能解决你的问题,请参考以下文章

Java并发编程:线程及同步的性能——线程池

Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题

Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题

Go语言之并发示例-Pool

golang goroutine例子[golang并发代码片段]

Java并发线程池监控