• c++ 经典服务器开源项目 Tinywebserver的使用与配置(百度智能云服务器安装ubuntu18.04可用公网ip访问)


    1 Tinywebserver介绍

    Linux下C++轻量级Web服务器,助力初学者快速实践网络编程,搭建属于自己的服务器.

    • 使用 线程池 + 非阻塞socket + epoll(ET和LT均实现) + 事件处理(Reactor和Proactor均实现) 的并发模型
    • 使用状态机解析HTTP请求报文,支持解析GET和POST请求
    • 访问服务器数据库实现web端用户注册、登录功能,可以请求服务器图片和视频文件
    • 实现同步/异步日志系统,记录服务器运行状态
    • 经Webbench压力测试可以实现上万的并发连接数据交换
      在这里插入图片描述

    2 准备环境和源码

    1. 系统环境:
      ubuntu 18.04(在centos上测试了很多次,但是由于环境的问题,安装的mysql一直找不到正确的用户名和密码)
      需要用到git apt-get install gitg++环境用来编译:apt-get install build-essential`

    2. 下载源码

      git clone https://github.com/qinguoyi/TinyWebServer.git
      
      • 1

    3. 安装配置mysql

    3.1安装mysql

    sudo apt-get install mysql-server
    
    • 1

    3.2 进行初始化配置

    sudo mysql_secure_installation
    
    • 1

    配置项较多,如下

    #1
    VALIDATE PASSWORD PLUGIN can be used to test passwords...
    Press y|Y for Yes, any other key for No: N (我的选项)
    #2
    Please set the password for root here...
    New password: (输入密码)
    Re-enter new password: (重复输入)
    #3
    By default, a MySQL installation has an anonymous user,
    allowing anyone to log into MySQL without having to have
    a user account created for them...
    Remove anonymous users? (Press y|Y for Yes, any other key for No) : N (我的选项)
    #4
    Normally, root should only be allowed to connect from
    'localhost'. This ensures that someone cannot guess at
    the root password from the network...
    Disallow root login remotely? (Press y|Y for Yes, any other key for No) : Y (我的选项)
    #5
    By default, MySQL comes with a database named 'test' that
    anyone can access...
    Remove test database and access to it? (Press y|Y for Yes, any other key for No) : N (我的选项)
    #6
    Reloading the privilege tables will ensure that all changes
    made so far will take effect immediately.
    Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y (我的选项)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    3.3检查mysql状态

    systemctl status mysql.service
    
    • 1

    在这里插入图片描述
    3.4 进入mysql

    sudo mysql -uroot -p
    
    • 1

    在这里插入图片描述
    3.5 根据readme操作mysql,这里其实就是写sql语句了
    分别包括创建数据库 yourdb,use相当于进入这个数据库,创建user表

    	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');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    可以利用以下命令查看表和表的内容:

    	show databases; //可以查看当前的数据库
    	show users;
    	select *from user;
    
    • 1
    • 2
    • 3

    4. 编译Tinywebserver

    4.1 首先需要确认main.cpp里的数据库和你mysql数据库配置相同。
    查看数据库名称和密码

    	cd /etc/mysql
    	sudo vim debian.cnf
    
    • 1
    • 2

    在这里插入图片描述
    然后打开main.cpp修改对应配置
    在这里插入图片描述
    4.2 编译Tinywebserver(编译运行)

    cd Tinywebserver
    
    
    sh ./build.sh
    
    • 1
    • 2
    • 3
    • 4

    编译时遇到的错误:fatal error: mysql.h: No such file or directory
    解决方法:安装链接库 apt-get install libmysqlclient-dev

     ./server
    
    • 1

    这时候命令是没有退出的,如果退出且日志里出现Mysql error大部分情况是因为数据库没连上,可以去github看一下相关问题

    5查看效果

    输入ip:9006就可以进行登录注册操作了,而且mysql数据库是动态更新的。
    可以用云服务器公网ip加9006进行访问
    在这里插入图片描述

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    MySQL简介
    LeetCode:342. 数位和相等数对的最大和(C++)
    在估值之前的“问题”以及什么是“格罗斯曼-斯蒂格利茨悖论”
    面向千兆宽带网络业务应用的高质量用户体验研究
    LLM大语言模型(十三):ChatGLM3-6B兼容Langchain的Function Call的一步一步的详细转换过程记录
    “沉迷”学习,神奇的“峰终定律”
    有哪些信息安全/网络安全/渗透测试/众测/CTF/红蓝攻防/漏洞测试等前沿技术/研究/技巧获取渠道?
    100行代码实现一个RISC-V架构下的多线程管理框架
    springboot + activiti实现activiti微服务化
    viple模拟器使用(一):线控模拟
  • 原文地址:https://blog.csdn.net/m0_54850467/article/details/126070729