您可以随时尝试执行
ulimit -n 2048。这只会重置当前shell的限制,并且您指定的数字不得超过硬限制
每个操作系统在配置文件中都有不同的硬限制设置。例如,可以在从/etc/system引导时设置Solaris上的硬打开文件限制。
set rlim_fd_max = 166384set rlim_fd_cur = 8192
在OS X上,必须在/etc/sysctl.conf中设置相同的数据。
kern.maxfilesperproc=166384kern.maxfiles=8192
在Linux下,这些设置通常位于/etc/security/limits.conf中。
有两种限制:
- 软 限制只是当前强制执行的限制
- 硬 极限标记了通过设置软极限不能超过的最大值
任何用户都可以设置软限制,而硬限制只能由root用户更改。限制是流程的属性。它们是在创建子进程时继承的,因此应在系统初始化期间在init脚本中设置系统范围的限制,并应在用户登录期间设置用户限制(例如,使用pam_limits)。
机器启动时通常会设置默认值。因此,即使您可以在单个shell中重置ulimit,也可能会发现它在重新引导时重置为先前的值。如果要更改默认值,则可能需要为存在ulimit命令grep您的引导脚本。



