基于epoll的高并发web服务器
项目介绍
基本情况介绍:
-
项目采用C/S模型,编写支持中小型应用的http,并结合mysql,理解常见互联网应用行为,做完该项目,你可以从技术上完全理解从你上网开始,到关闭浏览器的所有操作中的技术细节。 本项目采用epoll模型实现了一个微型web服务器,能进行静态页面的访问,还有CGI技术支持,还支持数据库操作。
开发环境:
- centos 7
- vim编辑器
- gcc/g++
- C++
技术支持
- 网络编程(TCP/IP协议,socket套接字,Http协议)
- 多线程技术
- shell脚本
- cgi技术
- mysql C api技术
- 使用epoll技术多路转接技术进行升级
项目流程介绍
我们要开发web服务器已经明确要使用http协议传送html文件,http只是应用层协议,我们仍然需要选择一个传输层的协议来完成我们的传输数据工作,所以开发协议选择是TCP+HTTP,也就是说服务器搭建浏览依照TCP,对数据进行解析和响应工作遵循HTTP的原则。这样我们的思路很清晰,编写一个TCP并发服务器,只不过收发消息的格式采用的是HTTP协议,项目总体流程图如下;
为了支持并发服务器,我们可以有多个选择,比如多进程服务器,多线程服务器,select,poll,epoll等多路IO工具都可以, 由于我们知道epoll在大量并发少量活跃的情况下效率很高,所以本次使用epoll。
request请求分析与response响应制作流程
epoll套接字建立连接流程
项目结构
项目拓展部分
首先是CGI机制,GET请求方式将参数写进环境变量,POST请求方式将请求正文写进了管道,不管是什么CGI程序只需在环境变量中和管道中参数给了这个项目很大可拓展性,一方面mysql程序可以将参数可以更新数据库,另一方面还可以放不同的CGI程序拿到数据。 项目还增加了设立了脚本可以一键部署在云服务器上还可以查看web服务器的状态。