linux – 如何从适用于其子代的Perl脚本中设置ulimit?

我有一个Perl脚本,它执行各种安装步骤来为我们公司设置开发盒.它运行各种 shell脚本,其中一些由于低于所需的ulimits(特别是在我的情况下为堆栈大小-s)而崩溃.

因此,我想设置一个适用于从我的主Perl中启动的所有脚本(子)的ulimit,但我不知道如何实现这一点 – 任何尝试从脚本中调用ulimit只会将其设置为特定的子shell,立即退出.

我知道在运行Perl脚本或使用/etc/security/limits.conf之前我可以调用ulimit但是我不希望用户知道任何这些 – 他们应该只知道如何运行脚本,为他们照顾所有这些.

我每次运行命令时都可以运行ulimit,比如ulimit -s BLA; ./cmd但我不想每次都复制这个,我觉得那里有一个更好,更清洁的解决方案.

另一个疯狂的“解决方法”是创建一个名为BLA.sh的包装脚本,它将设置ulimit并调用BLA.pl,但同样,这是我的脑海中的黑客,现在我有2个脚本(我甚至可以制作BLA.pl使用“ulimit -s BLA; ./BLA.pl –foo”调用自己,并根据它是否看到–foo或不同而采取不同的行为,但这甚至比以前更黑.

最后,显然我可以安装BSD :: Resource但我想避免使用外部依赖.

那么从Perl脚本中设置ulimit并将其应用于所有子节点的方法是什么?

谢谢.

解决方法

您已经回答了以下问题:使用 BSD::Resource.

Perl核心中没有任何与setrlimit接口的东西.如果你不能(或不会)使用标准方法,那么你必须使用hack.您已经描述的任何方法都可以使用. (注意,您可以创建一个子例程来预先添加ulimit -s BLA;对每个命令,然后使用该子而不是系统.)

相关文章

/etc/sysctl.conf这个目录主要是配置一些系统信息,/etc/sys...
1.作用 useradd或adduser命令用来建立用户帐号和创建用户的起...
它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅...
不管是我们在安装软件还是监测软件的使用性能,我们都要随时...
装好Tomcat7后,发现除了本机能访问外界访问不了,岂有此理。...
修改防火墙配置需要修改 /etc/sysconfig/iptables 这个文件,...