服务器模块测试

目录

测试逻辑

测试工具

测试


测试逻辑

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

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

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进行测试。 因为目前我们只是简单的对服务器的逻辑进行测试,具体的性能测试其实我们是不好做的。

相关推荐
PersistJiao23 分钟前
Spark 分布式计算中网络传输和序列化的关系(一)
大数据·网络·spark
黑客Ash3 小时前
【D01】网络安全概论
网络·安全·web安全·php
->yjy3 小时前
计算机网络(第一章)
网络·计算机网络·php
sinat_384241093 小时前
使用 npm 安装 Electron 作为开发依赖
服务器
朝九晚五ฺ3 小时前
【Linux探索学习】第十四弹——进程优先级:深入理解操作系统中的进程优先级
linux·运维·学习
自由的dream3 小时前
Linux的桌面
linux
xiaozhiwise4 小时前
Makefile 之 自动化变量
linux
摘星星ʕ•̫͡•ʔ4 小时前
计算机网络 第三章:数据链路层(关于争用期的超详细内容)
网络·计算机网络
Kkooe4 小时前
GitLab|数据迁移
运维·服务器·git