k8s中服务器容器tcp连接数量优化

netty的http1服务器在运行一段时间后会无法提供服务,返回客户端socket hang up
使用apipost测试抓包显示三次握手后被reset
客户端使用了大量短连接,如果能改成长连接就会消耗更少的连接,但是客户端逻辑无法掌控,只能修改服务器。
另外能保证客户端完成四次挥手也可以避免,但同样客户端逻辑无法掌控。

修改net/core/somaxconn

登录容器,cat /proc/sys/net/core/somaxconn显示128,对于一个服务器来说,这个限制太小了,可以放大。
但是k8s把容器的参数分类了,大部分的参数都属于unsafe,不能直接修改。

第一步:修改kubelet启动参数

kubelet启动增加参数:kubelet --allowed-unsafe-sysctls ‘net.core.somaxconn’
kubelet可能是通过配置文件启动的,比如/etc/systemd/system/kubelet.service.d/10-kubeadm.conf
修改后重启kubelet:systemctl restart kubelet
确认是否生效:
在这里插入图片描述

第二步:修改netty的yaml

在Deployment中spec-template-spec-containers下增加securityContext:

 securityContext:
         sysctls:
            - name: net.core.somaxconn
              value: "1024"

启动pod后查看somaxconn:
在这里插入图片描述

修改 TIME_WAIT 连接数量

cat /proc/net/tcp查看到tcp连接数非常多,连接状态01表示已连接,0A表示监听中,6表示TIME_WAIT
在这里插入图片描述

tcp状态值说明:

TCP_ESTABLISHED:1   TCP_SYN_SENT:2    TCP_SYN_RECV:3      TCP_FIN_WAIT1:4
TCP_FIN_WAIT2:5     TCP_TIME_WAIT:6  TCP_CLOSE:7         TCP_CLOSE_WAIT:8
TCP_LAST_ACL:9      TCP_LISTEN:10  TCP_CLOSING:11

需要修改关闭连接的等待时间(主动关闭的一方是TIME_WAIT,被动关闭一方是CLOSE_WAIT,需要根据具体情况),这也是k8s的unsafe参数

步骤一 修改kubelet配置,增加:

   --allowed-unsafe-sysctls net.core.somaxconn,net.ipv4.*

步骤二 修改deployment:

  securityContext:
    sysctls:
       - name: net.core.somaxconn                               
         value: "1024"
       - name: net.ipv4.tcp_fin_timeout
         value: "30"

相关推荐

  1. k8s容器以及基础设施优化

    2024-01-23 18:08:03       25 阅读
  2. k8s 容器、pod服务、svc服务 这几个的区别

    2024-01-23 18:08:03       16 阅读
  3. k8s,pod服务的状态和pod里面的容器的状态关系

    2024-01-23 18:08:03       20 阅读
  4. K8s: 在Pod将configmap数据注入容器

    2024-01-23 18:08:03       12 阅读
  5. K8s集群关于容器的设置

    2024-01-23 18:08:03       26 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-23 18:08:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-23 18:08:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-23 18:08:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-23 18:08:03       18 阅读

热门阅读

  1. processing集训day01

    2024-01-23 18:08:03       29 阅读
  2. elasticsearch高级应用

    2024-01-23 18:08:03       28 阅读
  3. 为什么两个向量的内积等于模长乘夹角?

    2024-01-23 18:08:03       29 阅读
  4. 人工智能工程师将来有什么发展

    2024-01-23 18:08:03       36 阅读
  5. idea编译打包前端vue项目

    2024-01-23 18:08:03       32 阅读
  6. MySQL新增、管理用户,控制访问【新手向】

    2024-01-23 18:08:03       38 阅读
  7. Qt容器QVector

    2024-01-23 18:08:03       36 阅读