#coding=utf-8
from socket import *
from threading import Thread
from time import sleep
# 处理客户端的请求并执行事情
def dealWithClient(newSocket,destAddr):
while True:
recvData = newSocket.recv(1024)
if len(recvData)>0:
print('recv[%s]:%s'%(str(destAddr), recvData))
else:
print('[%s]客户端已经关闭'%str(destAddr))
break
newSocket.close()
def main():
serSocket = socket(AF_INET, SOCK_STREAM)
serSocket.setsockopt(SOL_SOCKET, SO_REUSEADDR , 1)
localAddr = ('', 7788)
serSocket.bind(localAddr)
serSocket.listen(5)
try:
while True:
print('-----主进程,,等待新客户端的到来------')
newSocket,destAddr = serSocket.accept()
print('-----主进程,,接下来创建一个新的进程负责数据处理[%s]-----'%str(destAddr))
client = Thread(target=dealWithClient, args=(newSocket,destAddr))
client.start()
#因为线程中共享这个套接字,如果关闭了会导致这个套接字不可用,
#但是此时在线程中这个套接字可能还在收数据,因此不能关闭
#newSocket.close()
finally:
serSocket.close()
if __name__ == '__main__':
main()
158 python网络编程 - 多线程服务器
原创
©著作权归作者所有:来自51CTO博客作者阿甘兄_的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
java解决多线程服务器网络编程问题
一、案例...
网络 java socket nginx 多进程 -
网络编程(6)单进程多线程并发服务器实现
相比前面的fork方式的多进程服务器,用线程方式,更轻量级。最少用fork时,需要将内存新线程去处理它。 服务端代码:
socket 套接字 单进程多线程服务器 pthread_create 客户端 -
多线程服务器的常用编程模型
<br />这篇文章原本是前一篇博客《多线程服务器的常用编程模型》(以下简称《常用模型》
多线程 服务器 编程 io logging -
mongodb集群是怎么样搭建原理
"arbiterOnly" : false, "buildIndexes" : true, "hidden" : false, "priority" : 1, "tags" : { }
mongodb集群是怎么样搭建原理 服务器 配置文件 副本集