为了获得最佳产品性能,请在缺省的文件句柄数 1024 的基础上增加文件句柄数。
开始之前
要点: 在使用产品之前,请增加文件句柄数。大多数产品使用的文件句柄数超过了每个进程使用 1024 个文件句柄这一缺省限制。系统管理员可能需要进行此更改。
关于此任务
请确保您正确地完成下列步骤。如果此过程未正确完成,那么计算机将无法启动。
要增加 Linux® 计算机上的文件句柄数,请完成下列步骤:
- 以 root 用户身份登录。如果不具有 root 用户访问权,那么必须先获取 root 用户访问权,然后才能继续。
- 切换至 etc 目录。
注意: 如果决定在下一步中增加文件句柄数,请不要在计算机上保留空的 initscript 文件。否则,在下次重新启动计算机时,它将无法启动。
- 使用 vi 编辑器来编辑 etc 目录中的 initscript 文件。如果此文件不存在,那么输入 vi initscript 以创建此文件。
- 在第一行上,输入 ulimit -n 4096。关键在于
4096 远大于 1024,也就是远大于大多数 Linux 计算机上的缺省值。
要点: 请不要将句柄数设置得过大,因为这会对系统范围性能产生不良影响。
- 在第二行上,输入 eval exec "$4"。
- 在确保完成第 4 步和第 5 步之后,保存并关闭该文件。
- 可选: 通过修改 etc/security 目录中的
limits.conf 文件来限制对用户或组提供的句柄数。缺省情况下,SUSE Linux Enterprise Server(SLES)V9 和
Red Hat Enterprise Linux V4.0
都有此文件。如果没有此文件,请考虑在前面过程中的第 4 步使用较小的数目,例如 2048。请执行此操作,以便大多数用户对每个进程的所允许打开文件数具有合理的较低限制。如果在第
4 步使用相对较小的数目,那么是否执行此操作并不是很重要。但是,如果先前在第
4 步设置较大的数目,并且未在 limits.conf 文件中设置限制,那么会显著降低计算机性能。
以下 limits.conf 样本文件先对所有用户进行限制,然后对其他用户分别设置不同的限制。此样本假定在第
4 步中将句柄数设置为 8192。
* soft nofile 1024
* hard nofile 2048
root soft nofile 4096
root hard nofile 8192
user1 soft nofile 2048
user1 hard nofile 2048
注意,在以上示例中,首先使用
* 来设置对所有用户的限制。这些限制的优先级低于后面的限制的优先级。对于
root 用户,允许打开的句柄数较大;而对于 user1,允许打开的句柄数则介于两者之间。在进行更改之前,请务必阅读并理解
limits.conf 文件中包含的文档内容。