linux中ulimit命令怎么用-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)linux中ulimit命令怎么用的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)于2013年開始,先為海拉爾等服務(wù)建站,海拉爾等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為海拉爾企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

臨時(shí)系統(tǒng)調(diào)優(yōu)——ulimit命令

ulimit命令用法說明

命令:ulimit
功能:控制shell程序的資源
語法:ulimit [-aHS][-c <core文件上限>][-d <數(shù)據(jù)節(jié)區(qū)大小>][-f <文件大 小>][-m <內(nèi)存大小>][-n <文件數(shù)目>][-p <緩沖區(qū)大小>][-s <堆棧大小>][-t <CPU時(shí)間>][-u <程序數(shù)目>][-v <虛擬內(nèi)存大小>]
說明:ulimit為shell內(nèi)建指令,可用來控制shell執(zhí)行程序的資源。
參數(shù):
-a  顯示目前資源限制的設(shè)定。  
-c <core文件上限>  設(shè)定core文件的大值,單位為區(qū)塊。  
-d <數(shù)據(jù)節(jié)區(qū)大小>  程序數(shù)據(jù)節(jié)區(qū)的大值,單位為KB。  
-f <文件大小>  shell所能建立的大文件,單位為區(qū)塊。  
-H  設(shè)定資源的硬性限制,也就是管理員所設(shè)下的限制。  
-m <內(nèi)存大小>  指定可使用內(nèi)存的上限,單位為KB。  
-n <文件數(shù)目>  指定同一時(shí)間最多可打開的文件數(shù)。  
-p <緩沖區(qū)大小>  指定管道緩沖區(qū)的大小,單位512字節(jié)。  
-s <堆棧大小>  指定堆疊的上限,單位為KB。  
-S  設(shè)定資源的彈性限制。  
-t <CPU時(shí)間>  指定CPU使用時(shí)間的上限,單位為秒。  
-u <進(jìn)程數(shù)目>  用戶最多可啟動(dòng)的進(jìn)程數(shù)目。
-v <虛擬內(nèi)存大小>  指定可使用的虛擬內(nèi)存上限,單位為KB。

默認(rèn)情況下資源配置

# ulimit -a
...
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 30518
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 10240
cpu time               (seconds, -t) unlimited
max user processes              (-u) 1024
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

修改大進(jìn)程數(shù)

Linux對(duì)于每個(gè)用戶,系統(tǒng)限制其大進(jìn)程數(shù)。為提高性能,可以根據(jù)設(shè)備資源情況,設(shè)置各linux 用戶的大進(jìn)程數(shù),如10000

# ulimit -u 10000

修改大文件打開數(shù)

對(duì)于需要做許多 socket 連接并使它們處于打開狀態(tài)的 Java 應(yīng)用程序而言,需要設(shè)置每個(gè)進(jìn)程可打開的文件數(shù),缺省值是 1024。

# ulimit -n 65535

其它設(shè)置

建議設(shè)置成無限制(unlimited)的一些重要設(shè)置是:

數(shù)據(jù)段長(zhǎng)度

# ulimit -d unlimited

大內(nèi)存大小

# ulimit -m unlimited

堆棧大小

# ulimit -s unlimited

CPU 時(shí)間

# ulimit -t unlimited

虛擬內(nèi)存

# ulimit -v unlimited

注意:ulimited 不限制用戶可以使用的資源,但本設(shè)置對(duì)可打開的大文件數(shù)(max open files)
和可同時(shí)運(yùn)行的大進(jìn)程數(shù)(max user processes)無效。

永久系統(tǒng)調(diào)優(yōu)——/etc/security/limits.conf或者在/etc/security/limits.d/文件夾下新建文件寫入限制內(nèi)容

/etc/security/limits.conf 是Linux 資源使用配置文件,用來限制用戶對(duì)系統(tǒng)資源的使用。limits.conf 文件實(shí)際是 Linux PAM(插入式認(rèn)證模塊,Pluggable Authentication Modules)中 pam_limits.so 的配置文件,而且只針對(duì)于單個(gè)會(huì)話。/etc/security/limits.d/文件夾下定義的文件內(nèi)容和limits.conf格式一樣,但優(yōu)先級(jí)更高,建議在此文件夾下定義自己需要的。

limits.conf的格式

username|@groupname type resource limit
  • username|@groupname:設(shè)置需要被限制的用戶名,組名前面加@和用戶名區(qū)別。也可以用通配符'*'來做所有用戶的限制。

  • type:有 soft,hard 和 -,soft 指的是當(dāng)前系統(tǒng)生效的設(shè)置值。hard 表明系統(tǒng)中所能設(shè)定的大值。soft 的限制不能比har 限制高。用 - 就表明同時(shí)設(shè)置了 soft 和 hard 的值。

  • resource:

    • core - 限制內(nèi)核文件的大小

    • date - 大數(shù)據(jù)大小

    • fsize - 大文件大小

    • memlock - 大鎖定內(nèi)存地址空間

    • nofile - 打開文件的大數(shù)目

    • rss - 大持久設(shè)置大小

    • stack - 大棧大小

    • cpu - 以分鐘為單位的最多 CPU 時(shí)間

    • noproc - 進(jìn)程的大數(shù)目

    • as - 地址空間限制

    • maxlogins - 此用戶允許登錄的大數(shù)目

  • limit:具體數(shù)值

其它配置

啟用/etc/security/limits.conf功能

要使 limits.conf 文件配置生效,必須要確保 pam_limits.so 文件被加入到啟動(dòng)文件中。查看 /etc/pam.d/su 文件中有:

...
session required pam_limits.so
...

修改Linux環(huán)境變量

# vim /etc/profile
...
# 添加如下
ulimit -SHn 204800

:此處設(shè)置的204800必須大于/etc/security/limits.conf大打開數(shù)

舉例

例如:修改文件描述符大小(65536)

  • step1

# vim  /etc/security/limits.d/30-nofile.conf
...
*        soft       nofile    65536
*        hard        nofile    65536
  • step2

# vim /etc/pam.d/su
...
session required pam_limits.so
  • step3

# vim /etc/profile
...
ulimit -SHn 204800

注意!

如果是服務(wù)啟動(dòng)的上述設(shè)置不能起作用,需要在服務(wù)器文件中進(jìn)行設(shè)置,服務(wù)器文件一般位于下面的位置中:

  • /usr/lib/systemd/system 系統(tǒng)服務(wù)

  • /etc/systemd/system 用戶定義服務(wù)
    在服務(wù)文件中增加如下

    ...
    [Service]
    ...
    LimitCORE=infinity
    LimitNOFILE=65536
    LimitNPROC=65536

    上述三項(xiàng)是需要在服務(wù)中增加的內(nèi)容,65536是自定義的數(shù)目。
    通過如下命令可以查看當(dāng)前運(yùn)行的服務(wù)的資源限制

    # cat /proc/<PID>/limit

感謝各位的閱讀!關(guān)于“l(fā)inux中ulimit命令怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)頁(yè)名稱:linux中ulimit命令怎么用-創(chuàng)新互聯(lián)
分享路徑:http://bm7419.com/article44/cdjdee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)面包屑導(dǎo)航、微信小程序、網(wǎng)站建設(shè)、營(yíng)銷型網(wǎng)站建設(shè)網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管