多线程并发构建基础服务器

  • 多线程并发
threading的多线程并发

对比多进程并发: 
	* 消耗资源较少
	* 线程应该更注意共享资源的操作
	* 在python中应该注意GIL问题,网络延迟较高,线程并发也是一种可行的方法

实现步骤:
	1. 创建套接字,绑定监听
	2. 接收客户端请求,创建新的线程
	3. 主线程继续接收其他客户端连接
	4. 分支线程启动对应的函数处理客户端请求
	5. 当客户端断开,则分支线程结束

Cookie:
import traceback
traceback.print_exc()
	功能:更详细的打印异常信息
  • 具体代码
#多线程构建服务器
from socket import *
import os,sys
from threading import *
import traceback

Host = '0.0.0.0'
Port = 8888
Addr = (Host,Port)

#客户端处理函数
def handler(connfd):
	print('connect from:{}'.format(connfd.getpeername))
	while True:
		data = connfd.recv(1024)
		if not data:
			break
		print(data.decode())
		connfd.send(b'Receive request')
	connfd.close()


#创建套接字
s = socket()
s.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
s.bind(Addr)
s.listen(5)

#等待客户端请求
while True:
	try:
		connfd,addr = s.accept()
	except KeyboardInterrupt:
		s.close()
		sys.exit('服务端退出')
	except Exception as e:
		traceback.print_exc()
		continue

	#若不传递connfd将导致多线程共同使用全局变量connfd
	t = Thread(target = handler,args = (connfd,))
	t.setDaemon(True)
	t.start()
  
	# join函数是阻塞函数不能写在这里
	# t.join() 
	# 若在最后循环退出,则很久之内都不会执行故使用setDaemon给系统处理退出的线程
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值