服务器模块测试

目录

测试逻辑

测试工具

测试


测试逻辑

我们可以使用一个简单的业务处理逻辑来进行测试。

最简单的,我们业务逻辑就直接返回一个固定的字符串

复制代码
void Message(const PtrConnection&con,Buffer* inbuffer)    //模拟用户新数据回调
{
    inbuffer->MoveReadOffset(inbuffer->ReadSize());     //直接读完
    std::string resp = "OKOK";
    con->Send(resp.c_str(),resp.size()); 
}

void Close(const PtrConnection&con)  
{
    NORMAL_LOG("连接关闭: %p",con.get());
}
void Connect(const PtrConnection&con)  
{
    NORMAL_LOG("连接建立: %p",con.get());
}

//任意事件回调
void Event(const PtrConnection&con) 
{
    // NORMAL_LOG("事件到来:%d",con->Fd());
}

那么主函数的逻辑:

复制代码
int main()
{
    TcpServer svr(8080);
    svr.EnableInactiveRelease(30);
    svr.SetThreadCount(3);
    svr.SetConnectCallBack(Connect);
    svr.SetMessageCallBack(Message);
    svr.SetEventCallBack(Event);
    svr.SetCloseCallBack(Close);
    svr.Start();

    return 0;
}

测试工具

现阶段我们使用webbench来进行测试,

我们在Web Bench Homepage下载webbench的源码。然后传送到云服务器。

然后下载一个组件:

解下来解压缩

这个文件的后缀虽然是 .gz ,但是我们使用 tar zxvf 进行解压缩时会发现它提示并不是 .gz 格式,这时候我们可以把文件名的 .gz 后缀去掉,然后只用 tar xvf 进行解压缩

然后进入该目录,使用make命令进行编译

这时候我们会发现他会有一个报错

我们可以进入这个webbench.c文件找到报错的地方

很明显这个参数没用到,我们可以把这个参数删除

这时候再使用make编译就没问题了。

测试

接下来就是测试了。

webbench 的使用方式也很简单,我们可以看一下他的使用手册

-c 用于设置客户端数量,-t设置测试的时间,然后我们还需要给出服务器的网址,也就是给一个url,我们可以在url中携带一个参数,虽然也没什么用。

后续我们就可以开始进行测试了:

我们设置的服务器的端口号是8080,所以我们可以用下面的命令行来测试

复制代码
./webbench -c 5000 -t 30 http://127.0.0.1:8080/hello

其实我们这样子测试是不严谨的,因为我们使用的是云服务器,同时,我们测试的客户端和服务器都在一台主机上,所以他收到网络带宽的影响很小。 但是由于我们的云服务器的配置一般很低,带宽很小,资源也很少,所以我们目前也只能这样进行简单的测试,后续我们可以使用postman进行测试。 因为目前我们只是简单的对服务器的逻辑进行测试,具体的性能测试其实我们是不好做的。

相关推荐
石像鬼₧魂石2 小时前
内网渗透靶场实操清单(基于 Vulhub+Metasploitable 2)
linux·windows·学习·ubuntu
Danileaf_Guo2 小时前
256台H100服务器算力中心的带外管理网络建设方案
运维·服务器
橘子真甜~3 小时前
C/C++ Linux网络编程15 - 网络层IP协议
linux·网络·c++·网络协议·tcp/ip·计算机网络·网络层
Allen正心正念20254 小时前
网络编程与通讯协议综合解析
网络
bing_feilong4 小时前
ubuntu中的WIFI与自身热点切换
网络
拾贰_C4 小时前
【Linux | Windows | Terminal Command】 Linux---grep | Windows--- findstr
linux·运维·服务器
CodeByV4 小时前
【网络】UDP 协议深度解析:从五元组标识到缓冲区
网络·网络协议·udp
阿华hhh5 小时前
Linux系统编程(标准io)
linux·开发语言·c++
虹科网络安全5 小时前
艾体宝洞察 | 利用“隐形字符”的钓鱼邮件:传统防御为何失效,AI安全意识培训如何补上最后一道防线
运维·网络·安全
石像鬼₧魂石5 小时前
Kali Linux 网络端口深度扫描
linux·运维·网络