# YHJWS **Repository Path**: sometao/yhjws ## Basic Information - **Project Name**: YHJWS - **Description**: C++11实现的多线程Webserver - **Primary Language**: C++ - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2024-08-30 - **Last Updated**: 2024-08-30 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README TinyWebServer =============== Linux下C++轻量级Web服务器,助力初学者快速实践网络编程,搭建属于自己的服务器. * 使用 **线程池 + 非阻塞socket + epoll(ET和LT均实现) + 事件处理(Reactor和模拟Proactor均实现)** 的并发模型 * 使用**状态机**解析HTTP请求报文,支持解析**GET和POST**请求 * 访问服务器数据库实现web端用户**注册、登录**功能,可以请求服务器**图片和视频文件** * 实现**同步/异步日志系统**,记录服务器运行状态 * 经Webbench压力测试可以实现**上万的并发连接**数据交换 概述 ---------- > * C/C++ > * B/S模型 > * [线程同步机制包装类](https://gitee.com/hzfyhj3/yhjws/tree/master/lock) > * [http连接请求处理类](https://github.com/qinguoyi/TinyWebServer/tree/master/http) > * [半同步/半反应堆线程池](https://github.com/qinguoyi/TinyWebServer/tree/master/threadpool) > * [定时器处理非活动连接](https://github.com/qinguoyi/TinyWebServer/tree/master/timer) > * [同步/异步日志系统 ](https://github.com/qinguoyi/TinyWebServer/tree/master/log) > * [数据库连接池](https://github.com/qinguoyi/TinyWebServer/tree/master/CGImysql) > * [同步线程注册和登录校验](https://github.com/qinguoyi/TinyWebServer/tree/master/CGImysql) > * [简易服务器压力测试](https://github.com/qinguoyi/TinyWebServer/tree/master/test_presure) 压力测试 ------------- 在关闭日志后,使用Webbench对服务器进行压力测试,对listenfd和connfd分别采用ET和LT模式,均可实现上万的并发连接,下面列出的是两者组合后的测试结果. > * Proactor,LT + LT,93251 QPS ![image-20210918003813431](https://gitee.com/hzfyhj3/pic-go/raw/master/img/image-20210918003813431.png) > * Proactor,LT + ET,97459 QPS ![image-20210918004015260](https://gitee.com/hzfyhj3/pic-go/raw/master/img/image-20210918004015260.png) > * Proactor,ET + LT,80498 QPS ![image-20210918004102894](https://gitee.com/hzfyhj3/pic-go/raw/master/img/image-20210918004102894.png) > * Proactor,ET + ET,92167 QPS ![image-20210918004148536](https://gitee.com/hzfyhj3/pic-go/raw/master/img/image-20210918004148536.png) > * Reactor,LT + ET,69175 QPS ![image-20210918004323465](https://gitee.com/hzfyhj3/pic-go/raw/master/img/image-20210918004323465.png) > * 并发连接总数:10000 > * 访问服务器时间:5s > * 所有访问均成功 **注意:** 使用本项目的webbench进行压测时,若报错显示webbench命令找不到,将可执行文件webbench删除后,重新编译即可。 更新日志 ------- - [x] 解决请求服务器上大文件的Bug - [x] 增加请求视频文件的页面 - [x] 解决数据库同步校验内存泄漏 - [x] 实现非阻塞模式下的ET和LT触发,并完成压力测试 - [x] 完善`lock.h`中的封装类,统一使用该同步机制 - [x] 改进代码结构,更新局部变量懒汉单例模式 - [x] 优化数据库连接池信号量与代码结构 - [x] 使用RAII机制优化数据库连接的获取与释放 - [x] 优化代码结构,封装工具类以减少全局变量 - [x] 编译一次即可,命令行进行个性化测试更加友好 - [x] main函数封装重构 - [x] 新增命令行日志开关,关闭日志后更新压力测试结果 - [x] 改进编译方式,只配置一次SQL信息即可 - [x] 新增Reactor模式,并完成压力测试 快速运行 ------------ * 服务器测试环境 * Ubuntu版本16.04 * MySQL版本5.7.29 * 浏览器测试环境 * Windows、Linux均可 * Chrome * FireFox * 其他浏览器暂无测试 * 测试前确认已安装MySQL数据库 ```C++ // 建立yourdb库 create database yourdb; // 创建user表 USE yourdb; CREATE TABLE user( username char(50) NULL, passwd char(50) NULL )ENGINE=InnoDB; // 添加数据 INSERT INTO user(username, passwd) VALUES('name', 'passwd'); ``` * 修改main.cpp中的数据库初始化信息 ```C++ //数据库登录名,密码,库名 string user = "root"; string passwd = "root"; string databasename = "yourdb"; ``` * build ```C++ sh ./build.sh ``` * 启动server ```C++ ./server ``` * 浏览器端 ```C++ ip:9006 ``` 个性化运行 ------ ```C++ ./server [-p port] [-l LOGWrite] [-m TRIGMode] [-o OPT_LINGER] [-s sql_num] [-t thread_num] [-c close_log] [-a actor_model] ``` 温馨提示:以上参数不是非必须,不用全部使用,根据个人情况搭配选用即可. * -p,自定义端口号 * 默认9006 * -l,选择日志写入方式,默认同步写入 * 0,同步写入 * 1,异步写入 * -m,listenfd和connfd的模式组合,默认使用LT + LT * 0,表示使用LT + LT * 1,表示使用LT + ET * 2,表示使用ET + LT * 3,表示使用ET + ET * -o,优雅关闭连接,默认不使用 * 0,不使用 * 1,使用 * -s,数据库连接数量 * 默认为8 * -t,线程数量 * 默认为8 * -c,关闭日志,默认打开 * 0,打开日志 * 1,关闭日志 * -a,选择反应堆模型,默认Proactor * 0,Proactor模型 * 1,Reactor模型 测试示例命令与含义 ```C++ ./server -p 9007 -l 1 -m 0 -o 1 -s 10 -t 10 -c 1 -a 1 ``` - [x] 端口9007 - [x] 异步写入日志 - [x] 使用LT + LT组合 - [x] 使用优雅关闭连接 - [x] 数据库连接池内有10条连接 - [x] 线程池内有10条线程 - [x] 关闭日志 - [x] Reactor反应堆模型