mirror of
https://gitee.com/acl-dev/acl.git
synced 2024-12-15 09:20:52 +08:00
138 lines
2.8 KiB
C++
138 lines
2.8 KiB
C++
#include "stdafx.h"
|
|
#include "util.h"
|
|
|
|
static int __max_count = 10;
|
|
static int __dat_length = 100;
|
|
static char __local_addr[64];
|
|
static char __server_addr[64];
|
|
static bool __server_fixed = true;
|
|
|
|
static void run(void)
|
|
{
|
|
acl::socket_stream stream;
|
|
char* buf;
|
|
|
|
// 绑定本地地址
|
|
if (stream.bind_udp(__local_addr) == false)
|
|
{
|
|
printf("bind addr %s error %s\r\n",
|
|
__server_addr, acl::last_serror());
|
|
return;
|
|
}
|
|
|
|
// 设置远程服务地址
|
|
else
|
|
stream.set_peer(__server_addr);
|
|
|
|
stream.set_rw_timeout(1);
|
|
|
|
// 分配内存
|
|
buf = (char*) malloc(__dat_length + 1);
|
|
memset(buf, 'X', __dat_length);
|
|
buf[__dat_length] = 0;
|
|
|
|
char res[4096];
|
|
|
|
struct timeval begin;
|
|
gettimeofday(&begin, NULL);
|
|
|
|
int i = 0, ret;
|
|
for (; i < __max_count; i++)
|
|
{
|
|
// 服务端可能会用别的地址回复数据,所以需要重新设置远程服务地址
|
|
if (!__server_fixed)
|
|
stream.set_peer(__server_addr);
|
|
|
|
// 发送数据
|
|
if (stream.write(buf, __dat_length) == -1)
|
|
{
|
|
printf("write error %s\r\n", acl::last_serror());
|
|
break;
|
|
}
|
|
|
|
// 接收数据
|
|
else if ((ret = stream.read(res, sizeof(res) - 1, false)) == -1)
|
|
{
|
|
printf("read error %s\r\n", acl::last_serror());
|
|
break;
|
|
}
|
|
|
|
if (i % 1000 == 0)
|
|
{
|
|
res[ret] = 0;
|
|
printf("read >>> %s\r\n", res);
|
|
}
|
|
|
|
if (i % 1000 == 0)
|
|
{
|
|
snprintf(res, sizeof(res), "total: %d, curr: %d",
|
|
__max_count, i);
|
|
ACL_METER_TIME(res);
|
|
}
|
|
}
|
|
|
|
free(buf);
|
|
|
|
struct timeval end;
|
|
gettimeofday(&end, NULL);
|
|
|
|
// 计算速度
|
|
double spent = util::stamp_sub(&end, &begin);
|
|
printf("total: %d, curr: %d, spent: %.2f, speed: %.2f\r\n",
|
|
__max_count, i, spent, (i * 1000) / (spent > 1 ? spent : 1));
|
|
}
|
|
|
|
static void usage(const char* procname)
|
|
{
|
|
printf("usage: %s -h [help]\r\n"
|
|
" -s server_addr [default: 127.0.0.1:8888]\r\n"
|
|
" -l local_addr [default: 127.0.0.1:18888]\r\n"
|
|
" -o [server reply in other addr, default: no]\r\n"
|
|
" -n max_count [default: 10]\r\n"
|
|
" -N data_length [default: 100]\r\n",
|
|
procname);
|
|
}
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
int ch;
|
|
|
|
#ifdef WIN32
|
|
acl::acl_cpp_init();
|
|
#endif
|
|
acl::log::stdout_open(true);
|
|
|
|
snprintf(__server_addr, sizeof(__server_addr), "127.0.0.1:8888");
|
|
snprintf(__local_addr, sizeof(__local_addr), "127.0.0.1:18888");
|
|
|
|
while ((ch = getopt(argc, argv, "hs:l:on:N:")) > 0)
|
|
{
|
|
switch (ch)
|
|
{
|
|
case 'h':
|
|
usage(argv[0]);
|
|
return 0;
|
|
case 's':
|
|
snprintf(__server_addr, sizeof(__server_addr), "%s", optarg);
|
|
break;
|
|
case 'l':
|
|
snprintf(__local_addr, sizeof(__local_addr), "%s", optarg);
|
|
break;
|
|
case 'o':
|
|
__server_fixed = false;
|
|
break;
|
|
case 'n':
|
|
__max_count = atoi(optarg);
|
|
break;
|
|
case 'N':
|
|
__dat_length = atoi(optarg);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
run();
|
|
return 0;
|
|
}
|