前边我们了解了Reactor模式和Proactor模式,哪个性能更好呢?需要我们进行测试。前边我们用io_uring实现了Proactor模式,io_uring是2019年才加入到Linux内核中的,提供了三个系统调用函数。都有些抽象,我是直接来拿跑的。
无论是我们epoll实现的Reactor模式还是io_uring实现的Proactor模式,两者都是服务器端。QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。也就是说,qps这个参数是我们服务器端的一个重要性能。计算 qps的方法是通过统计在一定时间内处理的请求数,然后除以该时间间隔,得到平均每秒的请求数。 我们可以写一个客户端的代码,分别对epoll实现的Reactor服务器和io_uring实现的Proactor服务器进行测试。客户端大致流程:对服务端发起请求到接收到服务器回发的数据,统计期间的时间。
用getopt进行解析命令行参数 -t:表示线程数量 -c:表示连接数量 -n:表示请求数量
tcp客户端测试代码如下:
#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/time.h>
#include <pthread.h>
#include <arpa/inet.h>
//定义函数计算两个时间结点的差(单位: