#使用池来实现并发服务器
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()
使用池来实现并发服务器
Posted naniandiam
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用池来实现并发服务器相关的知识,希望对你有一定的参考价值。
以上是关于使用池来实现并发服务器的主要内容,如果未能解决你的问题,请参考以下文章
Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题
Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题