centos 7 修改 limits.conf 导致 ssh 连接失败

问题描述

由于项目性能测试需要上百万 tcp 连接,程序报错:

too many open files

查阅资料发现是系统参数 最大文件打开数 file-max 限制
于是根据网上资料修改 /etc/security/limits.conf

# 在文件末尾添加以下两行
*    soft    nofile    2000000
*    hard    nofile    2000000

重启服务器后发现无法 ssh 连接,查阅资料发现是 limits.conf 中配置的最大打开数超过了 /etc/sysctl.conf 中的最大文件打开数

fs.file-max = 1000000
fs.nr_open = 1000000

解决方法

  1. 如果目前已经无法连接 ssh
    需要进入 linux 单人模式将 limits.conf 中的数值修改回正常范围,详细步骤点击 参考链接

  2. 如果目前仍然可以 ssh

    • 修改 /etc/sysctl.conf 以下两项参数,数值设定根据实际需求,我这里需求 300 万
        fs.file-max = 3000000
        fs.nr_open = 3000000
      
    • 修改 /etc/security/limits.conf 在最后面添加以下两项参数,数值需要小于上一步所设定的数值,我这里设置为 200 万
        *    soft    nofile    2000000
        *    hard    nofile    2000000
      
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值