• CentOS6.x 下 /etc/security/limits.conf 被改错的故障经历


    Intro

    我司本小厂,每个员工都是身兼数职,所以开发人员直接登录线上服务器改东西是常态。有些开发人员,自持水平较高(的确水平也是较高,但缺乏对系统的敬畏),所以总是越俎代庖,改一些本身应该是线上运维人员改动的配置。本文提到的 /etc/security/limits.conf 两次改错导致的事故,皆是因为于此。

    In details

    The first time

    第一次是在 /etc/security/limits.conf 中加了两句:

    *   soft    nofile  unlimited
    *   hard    nofile  unlimited
    

    结果就是:
    所有用户无法登录。一登录,马上被踢出来。

    最后解决方法:
    单用户进系统把文件 /etc/security/limits.conf 改回来。

    原因:
    配置文件 /etc/security/limits.conf 中 nofile 的参数,只支持数字,"unlimited" 显然系统不认。

    The second time

    第二次也是在 /etc/security/limits.conf 中加了两句:

    root    soft    nofile  2000000
    root    hard    nofile  2000000
    

    结果是:

    • root 用户一登录,就被踢
    • 普通用户可登录,但 sudo su - 一切成 root 马上会被踢(但普通用户只支持 sudo su -

    解决方法:
    像前面文章 一次本地提权的实战演练 有提到的:

    1. 普通用户登录
    2. 用 DirtyCow(脏牛)本地提权
    3. 然后把 /etc/security/limits.conf 改回去。

    原因:

    1. 配置文件 /etc/security/limits.conf 中 nofile 的参数,其最大值不能大于 kernel 参数 NR_OPEN 的限制
    2. 而 kernel 2.6.32 里,NR_OPEN 的值缺省为 1024*1024=1048576
    3. 这里的 2000000>1048576,所以出错被踢

    稍稍延展一下,如果我一定要将 nofile 参数设置为 2000000呢?
    其实这也有办法,提高 kernel 里 NR_OPEN 的值即可,具体方法是:

    [[ ! -e /etc/sysctl.d ]] && mkdir /etc/sysctl.d;
    echo "fs.nr_open = 2000000" > /etc/sysctl.d/nr_open.conf;
    sysctl -w fs.nr_open=2000000;
    

    总结

    总而言之,言而总之:Linux 下配置文件 /etc/security/limits.conf 文件不要随意改动。我其实还是倾向于在启动服务的启动脚本里手工用 ulimit 命令来设置相关参数而不要直接在 /etc/security/limits.conf 文件里改。



    作者:haw_haw
    链接:https://www.jianshu.com/p/e3e7411f8afb
    来源:简书
    简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
  • 相关阅读:
    [Ps]图层混合模式——排除
    [Swift]自定义View
    [Swift]Closures概念与使用
    [Swift]Class的概念与使用
    [Swift][OC]tableView去掉顶部空白
    html引用css的四种方法
    plSQL技巧:“tns:无法解析指定的连接标识符”问题详解
    桌面任务栏右侧的输入法状态(也就是语言栏)不见了,通常有以下几种解决方法:
    Myeclipse下java.lang.OutOfMemoryError: Java heap space的解决
    Tomcat使用相对路劲来访问
  • 原文地址:https://www.cnblogs.com/augusite/p/10775115.html
Copyright © 2020-2023  润新知