您的位置:首页 > 理论基础 > 计算机网络

python实现协程方式的HTTP服务器,浏览器通过HTTP与之通信4

2019-07-11 11:29 1561 查看

        实际开发中,多线程多进程尽管效率很高,但是当服务器面临多并发,海量访问时,不可能说建立那么多的进程,线程数,而是通过更小粒度的协程方式来实现,这样可以更高地利用CPU资源。

       网络间通信是基于TCP协议传输数据的,而服务器与浏览器之间通信是基于HTTP协议的,那么下面基于python实现一个协程方式tcp服务器,浏览器可以基于http协议进行发送请求和解析。浏览器展示返回的一个标准的HTML网页,此外实现服务器解析客户端多次请求并且返回请求结果。即:客户端根据HTML里面的各种链接,再发送HTTP请求给服务器,拿到相应的图片、视频、Flash、JavaScript脚本、CSS等各种资源,最终显示出一个完整的页面

1.通过协程方式实现HTTP服务器

[code]import socket
import re
import gevent
from gevent import monkey

monkey.patch_all()

def service_client(new_socket):
"""为这个客户端返回数据"""

# 1. 接收浏览器发送过来的请求 ,即http请求
# GET / HTTP/1.1
# .....
request = new_socket.recv(1024).decode("utf-8")
# print(">>>"*50)
# print(request)

request_lines = request.splitlines()
print("")
print(">" * 20)
print(request_lines)

# GET /index.html HTTP/1.1
# get post put del
file_name = ""
ret = re.match(r"[^/]+(/[^ ]*)", request_lines[0])
if ret:
file_name = ret.group(1)
# print("*"*50, file_name)
if file_name == "/":
file_name = "/index.html"

# 2. 返回http格式的数据,给浏览器

try:
f = open("./html" + file_name, "rb")
except:
response = "HTTP/1.1 404 NOT FOUND\r\n"
response += "\r\n"
response += "------file not found-----"
new_socket.send(response.encode("utf-8"))
else:
html_content = f.read()
f.close()
# 2.1 准备发送给浏览器的数据---header
response = "HTTP/1.1 200 OK\r\n"
response += "\r\n"
# 2.2 准备发送给浏览器的数据---boy
# response += "hahahhah"

# 将response header发送给浏览器
new_socket.send(response.encode("utf-8"))
# 将response body发送给浏览器
new_socket.send(html_content)

# 关闭套接
new_socket.close()

def main():
"""用来完成整体的控制"""
# 1. 创建套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

# 2. 绑定
tcp_server_socket.bind(("", 7890))

# 3. 变为监听套接字
tcp_server_socket.listen(128)

while True:
# 4. 等待新客户端的链接
new_socket, client_addr = tcp_server_socket.accept()

# 5. 为这个客户端服务
gevent.spawn(service_client, new_socket)

# new_socket.close()

# 关闭监听套接字
tcp_server_socket.close()

if __name__ == "__main__":
main()

同样通过浏览器对服务器进行访问,实现上面的全部功能,如果是高并发的访问的话,效果更加明显。如下直接访问http服务器中的子网页,服务器顺利完成解析与响应。

尖叫提示:

核心的关系:进程,线程,协程都可以实现多任务模式

进程是资源分配的单位
线程是操作系统调度的单位
进程切换需要的资源很最大,效率很低
线程切换需要的资源一般,效率一般(当然了在不考虑GIL的情况下)
协程切换任务资源很小,效率高
多进程、多线程根据cpu核数不一样可能是并行的,但是协程是在一个线程中 所以是并发

统一声明:关于原创博客内容,可能会有部分内容参考自互联网,如有原创链接会声明引用;如找不到原创链接,在此声明如有侵权请联系删除哈。关于转载博客,如有原创链接会声明;如找不到原创链接,在此声明如有侵权请联系删除哈。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐