AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 523992
Accepted
Alexander Farber
Alexander Farber
Asked: 2013-07-18 03:10:47 +0800 CST2013-07-18 03:10:47 +0800 CST 2013-07-18 03:10:47 +0800 CST

找出其他用户的限制

  • 772

在 CentOS 6.4 / 64 位 - 如何找到用户“nobody”的限制?

因为我不能只是su - nobody打电话ulimit -a:

# id nobody
uid=99(nobody) gid=99(nobody) groups=99(nobody)

# su - nobody
This account is currently not available.

更新:

我在问:如何调用ulimit -aCentOS 用户nobody,以便我可以调整/etc/security/limits.conf该用户的最大打开文件数。

更多细节:

我有一个 perl 脚本(一个基于非分叉 TCP-sockets 的纸牌游戏守护进程),它正在由init(我为它创建了一个文件/etc/init/my_card_game.conf:)启动,但随后放弃了超级用户权限并运行为nobody:

sub drop_privs {
        my ($uid, $gid) = (getpwnam('nobody'))[2, 3];
        die "User nobody not found\n" unless $uid && $gid;

        umask(0);
        chdir('/tmp') or die "Can not chdir to /tmp: $!\n";
        #chroot('/tmp') or die "Can not chroot to /tmp: $!\n";

        # try to set the real, effective and save uid
        setgid($gid) or die "Can not set gid to $gid: $!\n";
        setuid($uid) or die "Can not set uid to $uid: $!\n";
        # try to regain privileges - this should fail
        die "Not able to drop privileges\n" if setuid(0) || setgid(0);
}

我想确保它有足够大的最大数量nofiles- 以便它可以为所有连接的客户端提供服务。

centos
  • 2 2 个回答
  • 3556 Views

2 个回答

  • Voted
  1. Best Answer
    David Schwartz
    2013-07-18T04:08:29+08:002013-07-18T04:08:29+08:00

    由于需要特权来提高硬资源限制,因此必须在放弃特权之前提高限制。您可以在脚本中添加代码来执行此操作。但最简单的方法是制作一个 shell 脚本来启动您的 perl 脚本。shell 脚本可以使用ulimit,因为它仍然具有特权。(用户与此无关。资源限制是进程的属性。)

    • 1
  2. andrew lorien
    2015-12-05T00:11:54+08:002015-12-05T00:11:54+08:00

    ulimit 手册页中的 -u 标志:

    -u 单个用户可用的最大进程数

    在 RedHat / CentOS 中,该文件/etc/security/limits.conf描述了每个用户的限制。因此,如果您的特定用户(例如您的 apache“nobody”用户)的文件描述符用完了,您可以在该文件的末尾添加一行(默认情况下它是空的)。将此从 4096 增加到 32768 为我们在 ColdFusion 10 / apache 2.2 / RedHat 服务器上解决了一个问题。

    • -1

相关问题

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 使用 crontab 和 /etc/cron.hourly,daily,weekly 的区别

  • 持续监控许多服务器运行状况的简单方法?

  • Hudson 无法在 tomcat5 中启动

  • CentOS 的依赖挑战

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve