python网络编程之并发服务器丶HTTP协议
该文档仅用作学习笔记,转载请表明出处
单进程服务器
- 完成一个简单的TCP服务器
案例v11:
'''
完成一个简单的TCP服务器
单进程服务器
'''
from socket import *
serSocket = socket(AF_INET,SOCK_STREAM)
#重复使用绑定的信息
serSocket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
localAddr = ('',7788)
serSocket.bind(localAddr)
serSocket.listen(5)
while True:
print('--------主进程:等待客户端到来--------')
newSocket,destAddr = serSocket.accept()
print('--------主进程:负责数据的处理--------')
try:
while True:
recvData = newSocket.recv(1024)
if len(recvData) > 0 :
print('recv[{}]:{}'.format(str(destAddr),recvData))
else:
print('[{}]客户端已经关闭'.format(str(destAddr)))
break
finally:
newSocket.close()
serSocket.close()
这种服务器:
- 同一时刻只能为一个客户进行服务,布恩那个同时为多个客户服务。
- 类似于找一个明星签字一样,客户需要耐心等待才可以获取到服务当服务器为一个客户端服务时,而另外的客户端发起了connect,只要服务器listen的队列有空闲的位置,就会为这个新客户端进行连接,并且客户端可以发送数据,但当服务器为这个新客户端服务时,可能一次性把所有数据接收完毕。
- 当recv接收数据时,返回值为空,即没有返回数据,那么意味着客户端已经调用了close关闭了;因此服务器通过判断recv接收数据是否为空来判断客户端是否已经下线。
多进程服务器
'''
多进程服务器
'''
from socket import *
from multiprocessing import *
from time import sleep
#处理客户端的请求并为其服务
def dealWithClient(newSocket,destAddr):
while True:
recvData = newSocket.recv(1024)
if len(recvData) > 0:
print('recv[{}]:{}'.format(str(destAddr), recvData))
else:
print('[{}]客户端已经关闭'.