一台内存在 8G 左右的服务器,可以同时维护多少个连接?

本文探讨了创建大量TCP连接的成本,包括三次握手的网络IO开销,内存占用的增长趋势,以及端口分配限制。重点在于通信的缓冲区需求和I/O对资源的影响,以及如何理解这些因素对单机性能的限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TCP连接代码示例:

public class Server {

    public static void main(String[] argv) throws IOException {

        var serverSocket = new ServerSocket();
        var addr = new InetSocketAddress(3001);
        serverSocket.bind(addr);
        var list = new LinkedList<>();

        while(true) {
            var client = serverSocket.accept();
            list.add(client);
            System.out.println(list.size());
        }
    }
}

public class Client {

    public static void main(String[] argv) throws IOException, InterruptedException {
        var clients = new LinkedList<>();
        for(int i = 0; i < 1000000; i++) {
            var client = new Socket("127.0.0.1", 3001);
            clients.add(client);
        }
        Thread.sleep(10000000);
    }
}

以上的这段程序有以下这几个现象:

  • 创建 100W 连接速度不是很快,这说明 TCP 连接创建有成本(3 次握手,都是网络 IO);

  • 用jps找到对应的进程的id,在用sudo cat /proc/{进程ID}/status | grep VmHWM可以看到实际的内存占用。按照这种增长趋势,8G 内存空间可以轻轻松松存放 100W 个连接。

但是如果单机建立太多的连接,会报一个Cannot assign requested address的异常,这是因为客户端连接服务端时,操作系统要为每个客户端分配一个端口,上面的程序很快会把端口号用尽。
所以,我们可以得出一个结论:核心的问题是,通信需要缓冲区,通信需要 I/O。这是因为通信占用资源,连接本身占用资源少。

1. Buffer是一个缓存区,用于存放将要输出或将要输入的数据,而Cache是一种缓存机制,用于存储最常用的数据,以便更快地访问。 2. Keepalived是一种高可用性软件,它可以在多个服务器之间实现负载均衡和故障转移。它的工作原理是使用虚拟IP地址和心跳检测机制来监测服务器的状态,并在必要时将流量重定向到其他服务器。 3. NFS是一种网络文件系统,它允许多台计算机共享文件。默认情况下,NFS使用TCP端口2049。要挂载NFS存储,可以使用mount命令。 4. Linux中常用的内存和磁盘使用命令包括free、df、du、top等。 5. Linux中的查看命令通常用于查看系统状态和性能指标,如top、htop、vmstat、sar等。 6. 可以使用head和tail命令来查看文件的头部和尾部,也可以使用sed、awk等命令来查看文件的中间部分。 7. 常用的Linux内存命令包括free、top、vmstat等,free命令可以显示系统的内存使用情况。 8. 处理Linux服务器性能问题的方法包括使用top命令查看系统资源的使用情况,使用ps命令查看进程的状态,使用netstat命令查看网络连接情况,使用iostat命令查看磁盘I/O性能等。 9. top命令可以查看CPU、内存进程等指标。 10. 可以使用smartctl命令来检查磁盘是否有问题。 11. 可以使用iostat命令来查看磁盘I/O性能。 12. LVS有三种模式:NAT模式、DR模式和TUN模式。NAT模式将真实服务器隐藏在一个虚拟IP地址后面,DR模式将真实服务器的网卡直接连接到LVS机器上,TUN模式则是在真实服务器和LVS机器之间建立一个隧道。 13. Keepalived有三个模块:VRRP模块、健康检查模块和通知模块。 14. Keepalived的健康检查机制包括TCP检查、HTTP检查、SMTP检查等,它会逐层检查服务器的状态,如果服务器出现故障,则会将流量重定向到其他可用的服务器上。 15. 可以使用zabbix自定义监测项来监测应用API是否正常,具体操作可以参考zabbix官方文档。 16. 监控脚本文件可以放在任何一个目录下,可以通过zabbix agent配置文件中的UserParameter选项来让agent与监控脚本交互。 17. 推送镜像到Docker Hub仓库的操作流程包括打标签、登录账户、上传镜像等步骤。 18. 在新版本的Kubernetes中,Docker被替换为CRI-O或Containerd等容器运行时,具体操作可以参考Kubernetes官方文档。 19. 如果Kubernetes节点出现notready状态,可以使用kubectl describe命令查看哪个服务出现了问题,并进行排查和修复。 20. Pod调度机制包括NodeSelector、Affinity和Taints & Tolerations等方式。 21. Kubernetes中的Service类型包括ClusterIP、NodePort、LoadBalancer和ExternalName等,每种类型都有不同的使用场景和特点。 22. Kubernetes中的持久化方式包括HostPath、Local、NFS、iSCSI等,每种方式都有不同的优缺点。 23. 在二进制部署的Kubernetes中,Pod的维护是通过kubelet组件来实现的。 24. Ansible中role的目录结构包括tasks、files、templates、vars、defaults、meta等目录,每个目录都有不同的作用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冲冲冲冲冲冲!!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值