多进程服务器
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.总结
通过为每个客户端创建一个进程的方式,能够同时为多个客户端进行服务
当客户端不是特别多的时候,这种方式还行,如果有几百上千个,就不可取了,因为每次创建进程等过程需要好较大的资源