基于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服务器的状态。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

自首的小偷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值