TCP百万连接数测试(Linux epoll)

一.基础

  • tcp连接通过五元组(源IP、源端口、目的IP、目的端口、协议)区分不同连接,其中有一个元素不一样即代表不同的连接
  • 如果只用一台客户端进行测试,由于端口数量最多为65535,最多只能实现65536个连接,所以此次测试服务器使用100个端口进行同时监听,此时可以使用少量客户端完成百万连接测试

二.配置

  • 测试前需要先解除系统的各项限制,配置如下

服务器配置

  • 虚拟机Uuntu2004,分配8个逻辑核心,8g内存
# 修改 /etc/sysctl.conf
net.ipv4.tcp_mem = 262144 524288 786432
net.ipv4.tcp_wmem = 2048 2048 4096      # tcp发送缓冲区,单位是字节
net.ipv4.tcp_rmem = 2048 2048 4096      # tcp读取缓冲区,单位为字节
net.nf_conntrack_max = 1048576          # 内核netfiter可以同时处理的任务数
fs.file-max = 1048576

# 修改 /etc/security/limits.conf
# 修改连接限制为 1000000+
* soft nofile 1040000   # 可以超过,超过时进行回收
* hard nofile 1040000   # 硬限制不能超过

客户端配置

  • 虚拟机Centos7,分配6个逻辑核心,8g内存,测试中负载80w+连接
  • 虚拟机Ubuntu1604 32位,分配4个逻辑核心,4g内存,测试中负载20w+连接
# 修改 /etc/sysctl.conf
net.ipv4.tcp_mem = 262144 524288 786432
net.ipv4.tcp_wmem = 1024 1024 2048      # tcp发送缓冲区,单位是字节
net.ipv4.tcp_rmem = 1024 1024 2048      # tcp读取缓冲区,单位为字节
net.nf_conntrack_max = 1048576          # 内核netfiter可以同时处理的任务数
fs.file-max = 1048576

# 修改 /etc/security/limits.conf
# 修改连接限制为 1000000+
* soft nofile 1040000   # 可以超过,超过时进行回收
* hard nofile 1040000   # 硬限制不能超过

三.代码实现

#define MAX_THREAD      8              // 线程池线程数量
#define MAX_PORT        100            // 服务器监听端口数量
#define MAX_CONN 405000  // 可以修改此变量控制客户端最大连接数

四.测试结果

在这里插入图片描述

五.参考资料

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
第一步:例如我们要测试内网结点A与B两台计算机之间的传输带宽,那么我们需要复制iperf.exe到这两台计算机硬盘中。   第二步:随意选择结点A作为服务端,而B作为客户端,在A上进入命令提示窗口运行iperf -s命令,这样iperf将以服务端方式启动,并且通过TCP的5001端口监听数据。(如图4)   第三步:接下来我们返回到B结点进入命令提示窗口,然后运行iperf -c 192.168.0.199 -t 60,这个命令是将B结点以客户端的方式运行,并且连接IP地址为192.168.0.199的服务端,监视测量数据时间是60秒。(如图5)   第四步:运行完毕客户端将自动开启1903端口连接服务端的5001端口,通过发送与接收数据包来实现测量带宽的目的。   第五步:与此同时我们在服务端上也可以看到有客户端连接5001端口的提示,这表明两个结点已经建立了相应的连接,数据通讯正常。(如图6)   第六步:由于我们之前是设置了测量时间间隔为60秒,所以在60秒过后客户端结点上就会显示出测量的具体数据,从A到B发送接收数据的速度为177Mbits/sec,由于以太网数据传输是双向双工的,所以百M网线理想状态传输速度应该是200Mbits/sec。(如图7)   第七步:当然我们还可以通过在客户端上执行iperf -c 192.168.0.199 -t 60 -i 2,这样将每隔两秒自动将测量结果显示出来,在最后再计算其平均值。(如图8)   通过简单的设置和简单的指令我们轻松实现了针对内网两个结点之间带宽传输速度的测量,当然iperf程序还支持很多参数,具体设置我们可以参考其帮助信息,比较常用的有-l 缓冲区大小,-m 显示tcp最大mtu值,-p 指定服务器端使用的端口或客户端所连接的端口,-u 使用udp协议,-w 指定TCP窗口大小,默认是8KB,-M 设定TCP数据包的最大mtu值等。另外在客户端上可以通过-n 指定传输的字节数,-r 单独进行双向传输测试,在服务端则可以通过-D参数以服务方式运行ipserf,以-R来停止iperf服务。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值