天天看點

JAVA ulimit_ulimit調優|設定普通使用者的ulimit值

個人總結:

如何設定普通使用者的ulimit值

1、vim /etc/profile

增加 ulimit -n 10240

source /etc/profile 重新啟動就不需要運作這個指令了。

2、修改/etc/security/limits.conf

增加

*      hard     nofile     10240

\\限制打開檔案數10240

3、測試,建立普通使用者,切換到普通使用者使用ulit -a 檢視是否修改成功。

相關介紹:

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

司伺服器需要調整 ulimit的stack size 參數調整為unlimited 無限,使用ulimit -s

unlimited時隻能在當時的shell見效,重開一個shell就失效了。。于是得在/etc/profile 的最後面添加ulimit -s

unlimited 就可以了,source /etc/profile使修改檔案生效。

如果你碰到類似的錯誤提示ulimit: max user processes: cannot modify limit: 不允許的操作 ulimit: open files: cannot modify limit: 不允許的操作

為啥root使用者是可以的?普通使用者又會遇到這樣的問題?

看一下/etc/security/limits.conf大概就會明白。

linux對使用者有預設的ulimit限制,而這個檔案可以配置使用者的硬配置和軟配置,硬配置是個上限。

超出上限的修改就會出“不允許的操作”這樣的錯誤。

在limits.conf加上

*        soft    noproc 10240

*        hard    noproc 10240

*        soft    nofile 10240

*        hard    nofile 10240

就是限制了任意使用者的最大線程數和檔案數為10240。