python多进程服务器

  1. 多进程tcp服务器
    	from multiprocessing import Process
    	from socket import *
    	
    	def rData(newSocket):
    	    try:
    	        while True:
    	            newData = newSocket.recv(1024)
    	            if len(newData) > 0:
    	                print("%s"%newData)
    	            else:
    	                print("关闭套接字")
    	                break
    	    finally:
    	            newSocket.close()
    	
    	
    	def main():
    	    tSocket = socket(AF_INET,SOCK_STREAM)
    	    
    	    #重复使用绑定的信息(服务起的端口 因为谁先调用close谁就等待2msl)
    	    tSocket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
    	
    	    #绑定
    	    bindAddr = ("",7288)
    	    tSocket.bind(bindAddr)
    	
    	    tSocket.listen(5)
    	
    	    try:
    	        while True:
    	            newSocket,ipData = tSocket.accept()
    	            p = Process(target=rData,args=(newSocket,)) #Process建立的进程主进程自动等待所有子进程结束
    	            p.start()
    	            
    	            #因为已经向子进程中copy了一份(引用),表示父进程中这个套接字也没有用处
    	            #所以关闭
    	            newSocket.close()
    	    finally:
    	        #当前所有的客户端服务完之后在进行关闭,表示不在接收 新的客户链接
    	        tSocket.close()
    	
    	if __name__ == "__main__":
    	    main()
    
  2. 进程池版tcp服务器
    	from multiprocessing import Pool
    	from socket import *
    	
    	def rData(newSocket):
    	    try:
    	        while True:
    	            socketData = newSocket.recv(1024)
    	            if len(socketData) > 0:
    	                print("%s"%socketData)
    	            else:
    	                print("关闭套接字")
    	                break
    	    finally:
    	            newSocket.close()
    	
    	def main():
    	    tSocket = socket(AF_INET,SOCK_STREAM)
    	
    	    #重复使用绑定信息
    	    tSocket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
    	
    	    #绑定端口
    	    bindAddr = ("",7288)
    	    tSocket.bind(bindAddr)
    	
    	    tSocket.listen(5)
    	
    	
    	    #创建进程  创建进程池的时候不要放在循环里
    	    p = Pool() #这个进程内存无线大
    	    while True:
    	        newSocket,socketData = tSocket.accept()
    	        
    	        #执行进程
    	        p.apply_async(rData,args=(newSocket,)) #无线把新的套接字放在进程池里运行
    	        
    	        #因为已经想子进程中copy了一份(引用),并且父进程中这个套接字也没有用处了
    	        #所以关闭
    	        newSocket.close()
    	
    	    p.close() #关闭进程池
    	    p.join() #主进程等待进程池里所有的子进程运行结束
    	
    	
    	if __name__ == "__main__":
    	    main()
    
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

只因为你温柔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值