/TinyWeb

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

Primary LanguageC++

  • 前言

    本项目是基于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 git@github.com: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