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核数不一样可能是并行的,但是协程是在一个线程中 所以是并发
统一声明:关于原创博客内容,可能会有部分内容参考自互联网,如有原创链接会声明引用;如找不到原创链接,在此声明如有侵权请联系删除哈。关于转载博客,如有原创链接会声明;如找不到原创链接,在此声明如有侵权请联系删除哈。
相关文章推荐
- python实现外部静态服务器,浏览器通过HTTP与之通信2
- python实现外部静态服务器,浏览器通过HTTP与之通信
- HTTP 通信, 三种方式XML 解析,并通过 Hander 实现异步消息处理
- Python爬虫通过替换http request header来欺骗浏览器实现登录功能
- QTE下通过Http协议以同步方式与Web服务器通信的实现
- Python爬虫通过替换http request header来欺骗浏览器实现登录
- 系出名门Android(10) - HTTP 通信, XML 解析, 通过 Hander 实现异步消息处理
- PHP-curl通过GET或POST方式实现http、https请求
- HTTP 通信, XML 解析, 通过 Hander 实现异步消息处理
- 通过XMLHttpRequest和jQuery实现ajax的几种方式
- android客户端通过Get方式提交参数给服务器,使用URL和HttpURLConnection实现,以及乱码问题解决
- python实现的json数据以HTTP GET,POST,PUT,DELETE方式页面请求
- android中的http通信---(3)通过get、post方式传数据给服务器
- git通过http方式clone的实现[原创]
- c++实现发送http请求通过get方式获取网页源代码
- python通过get,post方式发送http请求和接收http响应的方法
- Android学习笔记---28_网络通信之通过HTTP协议实现文件上传,组拼http 的post方法,传输内容
- python编程_python通过get方式,post方式发送http请求和接收http响应_import urllib模块,import urllib2模块,import httplib模块
- python通过get,post方式发送http请求和接收http响应的方法
- 通过XMLHttpRequest和jQuery实现ajax的几种方式