Skip to content
forked from Buerzhu/TinyWeb

基于C++线程池的轻量级Web并发服务器

Notifications You must be signed in to change notification settings

Catchen98/TinyWeb

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

  • 前言

    本项目是基于C++线程池的轻量级Web并发服务器,事件处理模式采用Reactor模式,主线程只负责监听文件描述符是否有事件发生,读写数据、接收新的连接、以及处理客户请求均在工作线程中实现;使用半同步/半异步模式,每个线程(主线程和工作线程)都通过一个epoll维护自己的事件循环,它们各自独立地监听不同事件。使用C++ 11的atomic原子变量来同步线程访问从而避免同步错误;使用STL的优先队列作为定时器容器来回收非活动长连接。本项目的具体设计思路可以参照本人的知乎文章C++网络编程入门:轻量级Web并发服务器开发,纯属抛砖引玉,欢迎大佬们批评指正。

  • 运行环境

    (1).系统:Ubuntu16.04;

    (2).语言:C++ 11及以上版本;

  • 支持功能

    (1).支持Get请求; (2).支持长连接/短连接; (3).支持ipv4/ipv6;(4).支持tcp;(5).支持请求静态内容(6).支持并发请求

  • 开始运行

    (1).下载程序;

    git clone [email protected]:Buerzhu/TinyWeb.git

    (2).打开新终端,指定ip地址和端口运行服务器程序:

    cd ~/TinyWeb/Server/Debug

    ./server 127.0.0.1 12345

    (3).打开新终端,指定ip地址、端口、客户连接数运行压力测试程序:

    cd ~/TinyWeb/Client/Debug

    ./client 127.0.0.1 12345 1000

About

基于C++线程池的轻量级Web并发服务器

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 72.6%
  • Makefile 26.7%
  • Other 0.7%