快捷搜索: 王者荣耀 脱发

基于epoll的高并发web服务器

项目介绍

基本情况介绍:

    项目采用C/S模型,编写支持中小型应用的http,并结合mysql,理解常见互联网应用行为,做完该项目,你可以从技术上完全理解从你上网开始,到关闭浏览器的所有操作中的技术细节。 本项目采用epoll模型实现了一个微型web服务器,能进行静态页面的访问,还有CGI技术支持,还支持数据库操作。

开发环境:

  1. centos 7
  2. vim编辑器
  3. gcc/g++
  4. C++

技术支持

  1. 网络编程(TCP/IP协议,socket套接字,Http协议)
  2. 多线程技术
  3. shell脚本
  4. cgi技术
  5. mysql C api技术
  6. 使用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服务器的状态。

经验分享 程序员 微信小程序 职场和发展