Web开发

首页 » 常识 » 诊断 » python进阶教程web服务器多进程
TUhjnbcbe - 2023/3/3 18:46:00

多进程服务器

1.多进程服务器

fromsocketimport*

frommultiprocessingimport*

fromtimeimportsleep

#处理客户端的请求并为其服务

defdealWithClient(newSocket,destAddr):

whileTrue:

recvData=newSocket.recv()

iflen(recvData)0:

print(recv[%s]:%s%(str(destAddr),recvData))

else:

print([%s]客户端已经关闭%str(destAddr))

break

newSocket.close()

defmain():

serSocket=socket(AF_INET,SOCK_STREAM)

serSocket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)

localAddr=(,)

serSocket.bind(localAddr)

serSocket.listen(5)

try:

whileTrue:

print(-----主进程,,等待新客户端的到来------)

newSocket,destAddr=serSocket.accept()

print(-----主进程,,接下来创建一个新的进程负责数据处理[%s]-----%str(destAddr))

client=Process(target=dealWithClient,args=(newSocket,destAddr))

client.start()

#因为已经向子进程中copy了一份(引用),并且父进程中这个套接字也没有用处了

#所以关闭

newSocket.close()

finally:

#当为所有的客户端服务完之后再进行关闭,表示不再接收新的客户端的链接

serSocket.close()

if__name__==__main__:

main()

2.总结

通过为每个客户端创建一个进程的方式,能够同时为多个客户端进行服务

当客户端不是特别多的时候,这种方式还行,如果有几百上千个,就不可取了,因为每次创建进程等过程需要好较大的资源

1
查看完整版本: python进阶教程web服务器多进程