個人總結:
如何設定普通使用者的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。