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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值