ulimit設定--最大檔案開啟數
阿新 • • 發佈:2019-01-30
ulimit -a 用來顯示當前的各種使用者程序限制。
Linux對於每個使用者,系統限制其最大程序數。為提高效能,可以根據裝置資源情況,設定各linux 使用者的最大程序數,下面我把某linux使用者的最大程序數設為10000個:
ulimit -u 10000
對於需要做許多 socket 連線並使它們處於開啟狀態的Java 應用程式而言,最好通過使用 ulimit -n xx 修改每個程序可開啟的檔案數,預設值是 1024。
ulimit -n 4096 將每個程序可以開啟的檔案數目加大到4096,預設為1024
其他建議設定成無限制(unlimited)的一些重要設定是:
資料段長度:ulimit -d unlimited
最大記憶體大小:ulimit -m unlimited
堆疊大小:ulimit -s unlimited
CPU 時間:ulimit -t unlimited
虛擬記憶體:ulimit -v unlimited
生成coredump:ulimit -c unlimited
要對所有使用者生校,加到/etc/profile就好了~
如果你碰到類似的錯誤提示ulimit: max user processes: cannot modify limit: 不允許的操作 ulimit: open files: cannot modify limit: 不允許的操作
看一下/etc/security/limits.conf大概就會明白。
linux對使用者有預設的ulimit限制,而這個檔案可以配置使用者的硬配置和軟配置,硬配置是個上限。
超出上限的修改就會出“不允許的操作”這樣的錯誤。
在limits.conf加上
* soft nofile 65535
Linux對於每個使用者,系統限制其最大程序數。為提高效能,可以根據裝置資源情況,設定各linux 使用者的最大程序數,下面我把某linux使用者的最大程序數設為10000個:
ulimit -u 10000
對於需要做許多 socket 連線並使它們處於開啟狀態的Java 應用程式而言,最好通過使用 ulimit -n xx 修改每個程序可開啟的檔案數,預設值是 1024。
ulimit -n 4096 將每個程序可以開啟的檔案數目加大到4096,預設為1024
其他建議設定成無限制(unlimited)的一些重要設定是:
資料段長度:ulimit -d unlimited
最大記憶體大小:ulimit -m unlimited
堆疊大小:ulimit -s unlimited
CPU 時間:ulimit -t unlimited
虛擬記憶體:ulimit -v unlimited
生成coredump:ulimit -c unlimited
要對所有使用者生校,加到/etc/profile就好了~
公司伺服器需要調整 ulimit的stack size 引數調整為unlimited 無限,使用ulimit -s unlimited時只能在當時的shell見效,重開一個shell就失效了。。於是得在/etc/profile 的最後面新增ulimit -s unlimited 就可以了,source /etc/profile使修改檔案生效。
看一下/etc/security/limits.conf大概就會明白。
linux對使用者有預設的ulimit限制,而這個檔案可以配置使用者的硬配置和軟配置,硬配置是個上限。
超出上限的修改就會出“不允許的操作”這樣的錯誤。
在limits.conf加上
* soft nofile 65535
* hard nofile 65535
tony soft nofile 65535
tony hard nofile 65535
有時*不會對所有使用者生校,可以單獨為每個使用者配置。配置後退出shell重啟登入就生校了。