功能說明:控制shell程式的資源。
語 法:ulimit [-aHS][-c <core檔案上限>][-d <資料節區大小>][-f <檔案大 小>][-m <記憶體大小>][-n <檔案數目>][-p <緩衝區大小>][-s <堆疊大 小>][-t <CPU時間>][-u <程式數目>][-v <虛擬記憶體大小>]
補充說明:ulimit為shell內建指令,可用來控制shell執行程式的資源。
參 數:
-a 顯示目前資源限制的設定。
-c <core檔案上限> 設定core檔案的最大值,單位為區塊。
-d <資料節區大小> 程式資料節區的最大值,單位為KB。
-f <檔案大小> shell所能建立的最大檔案,單位為區塊。
-H 設定資源的硬性限制,也就是管理員所設下的限制。
-m <記憶體大小> 指定可使用記憶體的上限,單位為KB。
-n <檔案數目> 指定同一時間最多可開啟的檔案數。
-p <緩衝區大小> 指定管道緩衝區的大小,單位512位元組。
-s <堆疊大小> 指定堆疊的上限,單位為KB。
-S 設定資源的彈性限制式。
-t <CPU時間> 指定CPU使用時間的上限,單位為秒。
-u <程式數目> 使用者最多可開啟的程式數目。
-v <虛擬記憶體大小> 指定可使用的虛擬記憶體上限,單位為KB。
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使修改檔案生效。
PS:如果你碰到類似的錯誤提示
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。