测试tcp连接数工具_[NewLife.Net]单机400万长连接压力测试

目标

对网络库NewLife.Net进行单机百万级长连接测试,并持续收发数据,检测网络库稳定性

【2020年8月1日晚上22点】

先上源码:https://github.com/NewLifeX/NewLife.Net

结论,8月1日晚达到200万,8月2日下午达到404万。

上一次百万级压测是2017年4月1日,失败了,只达到84.5万。后来做了一次吞吐量压测。

技术革新

自上一次百万级压测(2017.4.1)以来,网络库进行了诸多细节优化(没有调整架构),特别优化了内存拷贝和多线程操作。

上次购买了20多台高配大数据服务器(16C64G和8C16G),每台发起5万Tcp长连接,纯人肉方式,相当累。这次从泥水佬那里学到本地配置多IP地址建立更多连接的方式,大大节省了服务器资源和人力成本。每台服务器设置20个IP,每个IP发起5万Tcp长连接。

测试程序也从.Net 4.5升级到了.Net Core 3.1,性能提升可观。

服务器资源

阿里云上海区共购买6台12C24G的计算型C5服务器,按照抢占型实例购买,晚上特别便宜。平时3.7每小时的价格,现在0.355就可以拿到。

fa2a0430fbfc7699071b87d01e8686d3.png

这次压测对网络要求极高,所以选择的服务器必须有高带宽以及高PPS,务必是同一个机房,便于内网测试。

第一次购买的002因为设置IP失误导致弄残了服务器,不得不释放重新购买。

41986408ca833120c73b2a5b3a7931dd.png

001~004配置多IP花了很长时间,后来才想到用命令批量设置。

默认每个ECS只有一个私网IP,可以再增加9个,一共10个。

经@景洋 提醒,ECS可以通过 绑定弹性网卡,得到20个IP地址,后面的005/002/006都有20个IP。

9de47beb78f7bc3377d270c61d6dc2bd.png

环境准备

优化Tcp参数

Windows默认只能使用5000个端口,需要优化Tcp参数设置。

把码神工具拷贝到服务器,直接双击运行,工具->网络调试工具,内容区点击右键,查看Tcp参数,可以看到MaxUserPort是5000,右键还有个“设置最大Tcp”把各个参数值设置为最优。无需重启,直接生效。

码神工具也可以在这里下载,http://x.newlifex.com/XCoder_Install.exe

码神工具源码:https://github.com/NewLifeX/XCoder

155d4fd5512e5c79df4034c31a50ea09.png

安装.NET Core运行时

.NET Core 3.1.6 也需要拷贝上去安装,或者直接从 http://get.dot.net 下载。服务器网络非常快。

a162b3afdf5e2fd3e8dbe50ce7acd189.png

网卡设置

为了增加每台测试端的连接数,我们需要用netsh命令增加IP地址。这些IP地址来自于ECS设置的辅助私网IP。请一定要申请辅助私网IP以后再去设置网卡,未申请的IP地址可能出问题,第一次购买的002就是这样残废了。

设置主网卡辅助私网IP

369a4c562a83ab0a96fdc2f97f8197f4.png

dd9be735bc25e3f843cebc20bc3de080.png

设置弹性网卡辅助私网IP

1f0104f8e87d4e64edad586d48d0e10b.png

6cb6f4b2c79990149c9b30817f02bb39.png

ca8736b3d1c725ede9e619c6f25d8596.png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您又发现了一个问题,这个代码确实没有实现返回上一代的功能。在代码中添加一个变量 `generation` 来记录当前的代数,然后在回滚时将代数减1,就可以回到上一代。可以按照以下方式修改代码: ```c++ int generation = 0; // 添加一个变量来记录当前的代数 A.init(ROWS, COLS, life); while (true) { A.display(ROWS, COLS, life); string input; loop: cout << "Type 's' to save, 'l' to load, 'c' to change,'s' to stop, 'r' to rollback, or any other key to continue: "; cin >> input; if (input == "s") { string fileName; cout << "Enter file name: "; cin >> fileName; A.saveBoard(life, fileName, ROWS, COLS); } else if (input == "r") { if (generation == 0) { cout << "Cannot rollback anymore!" << endl; } else { generation--; for (int i = 0; i < ROWS; i++) { for (int j = 0; j < COLS; j++) { life[i][j] = oldlife[i][j]; } } A.display(ROWS, COLS, life); } } else if (input == "l") { string fileName; cout << "Enter file name: "; cin >> fileName; A.loadBoard(life, fileName, ROWS, COLS); } else if (input == "c") { int x, y; cin >> x >> y; if (x >= 0 && x < ROWS && y >= 0 && y < COLS) { life[x][y] = ~life[x][y]; A.display(ROWS, COLS, life); goto loop; } else { cout << "Invalid position!" << endl; } } else if (input == "s") { break; } A.run(ROWS, COLS, life, newLife); generation++; // 更新当前的代数 for (int i = 0; i < ROWS; i++) { for (int j = 0; j < COLS; j++) { oldlife[i][j] = life[i][j]; } } } ``` 这样,当用户输入"r"时,如果当前的代数为0,代码会输出一个提示信息;否则,代码会将代数减1,并将oldlife的值复制到life中,然后再显示出来,实现了返回上一代的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值