首页
/ WebServer 项目下载及安装教程

WebServer 项目下载及安装教程

2024-12-05 21:15:39作者:董宙帆

1. 项目介绍

WebServer 是一个基于 C++11 实现的轻量级 Web 服务器。该项目使用了线程池、非阻塞 socket、epoll(支持 ET 和 LT 模式)以及事件处理(Reactor 和模拟 Proactor 均实现)的并发模型。它支持解析 GET 和 POST 请求,并能够访问服务器数据库实现用户注册和登录功能。此外,服务器还可以请求播放服务器上的图片和视频文件,并实现了同步/异步日志系统以记录服务器运行状态。

2. 项目下载位置

要下载 WebServer 项目,请使用以下命令:

git clone https://github.com/white0dew/WebServer.git

3. 项目安装环境配置

3.1 服务器测试环境

  • 操作系统: Ubuntu 16.04
  • 数据库: MySQL 5.7.29

3.2 浏览器测试环境

  • 操作系统: Windows 或 Linux
  • 浏览器: Chrome 或 FireFox

3.3 环境配置示例

3.3.1 安装 MySQL

在 Ubuntu 上安装 MySQL:

sudo apt-get update
sudo apt-get install mysql-server

安装完成后,启动 MySQL 服务:

sudo systemctl start mysql

3.3.2 创建数据库和表

登录 MySQL 并创建数据库和表:

mysql -u root -p

CREATE DATABASE yourdb;
USE yourdb;

CREATE TABLE user(
    username CHAR(50) NULL,
    passwd CHAR(50) NULL
) ENGINE=InnoDB;

INSERT INTO user(username, passwd) VALUES('name', 'passwd');

3.3.3 配置数据库信息

修改 main.cpp 文件中的数据库初始化信息:

string user = "root";
string passwd = "root";
string databasename = "yourdb";

4. 项目安装方式

4.1 编译项目

进入项目目录并执行编译脚本:

cd WebServer
sh build.sh

4.2 启动服务器

编译完成后,启动服务器:

./server

5. 项目处理脚本

5.1 启动脚本

启动服务器时,可以使用以下命令进行个性化配置:

./server [-p port] [-l LOGWrite] [-m TRIGMode] [-o OPT_LINGER] [-s sql_num] [-t thread_num] [-c close_log] [-a actor_model]

5.2 参数说明

  • -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 模型)

5.3 测试示例

以下是一个测试示例命令及其含义:

./server -p 9007 -l 1 -m 0 -o 1 -s 10 -t 10 -c 1 -a 1
  • 端口: 9007
  • 日志写入方式: 异步写入
  • 模式组合: LT + LT
  • 优雅关闭连接: 使用
  • 数据库连接池: 10 条连接
  • 线程池: 10 条线程
  • 日志: 关闭
  • 反应堆模型: Reactor

通过以上步骤,您可以成功下载、配置并运行 WebServer 项目。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
166
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
88
568
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
17
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉应用开发框架。IoC,Rest,宏路由,Json,中间件,参数绑定与校验,文件上传下载,OAuth2,MCP......
Cangjie
94
15
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
17
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
954
564