• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統(tǒng)計(jì)

            最新評(píng)論

            Linux系統(tǒng)中打開(kāi)文件數(shù)量的查看方法

            ulimit -n 4096
                也就是限制用戶(hù)的最大文件打開(kāi)數(shù)為4096個(gè)
                在網(wǎng)上查了關(guān)于怎么查看文件打開(kāi)數(shù)的文章大致有兩種說(shuō)法
                /proc/sys/fs/file-nr
                該文件與 file-max 相關(guān),它有三個(gè)值:
                已分配文件句柄的數(shù)目[來(lái)源[url]www.iocblog.net[/url]]
                已使用文件句柄的數(shù)目
                文件句柄的最大數(shù)目
                該文件是只讀的,僅用于顯示信息。
                查看所有進(jìn)程的文件打開(kāi)數(shù)
                lsof |wc -l
                查看某個(gè)進(jìn)程打開(kāi)的文件數(shù)
                lsof -p pid |wc -l
             
            系統(tǒng)設(shè)置--ulimit
            語(yǔ)  法: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)存大小>]

            補(bǔ)充說(shuō)明:ulimit為shell內(nèi)建指令,可用來(lá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í)間最多可開(kāi)啟的文件數(shù)。 
              -p <緩沖區(qū)大小>  指定管道緩沖區(qū)的大小,單位512字節(jié)。 
              -s <堆疊大小>  指定堆疊的上限,單位為KB。 
              -S  設(shè)定資源的彈性限制。 
              -t <CPU時(shí)間>  指定CPU使用時(shí)間的上限,單位為秒。 
              -u <程序數(shù)目>  用戶(hù)最多可開(kāi)啟的程序數(shù)目。 
              -v <虛擬內(nèi)存大小>  指定可使用的虛擬內(nèi)存上限,單位為KB。
             
             
            Linux系統(tǒng)的文件句柄數(shù)量問(wèn)題
            linux下面部署應(yīng)用的時(shí)候,有時(shí)候會(huì)遇上socket/file: can‘t open so many files的問(wèn)題,其實(shí)linux是有文件句柄限制的(就像winxp?),而且默認(rèn)不是很高,一般都是1024,作為一臺(tái)生產(chǎn)服務(wù)器,其實(shí)很容易就達(dá)到這個(gè)數(shù)量,因此我們需要把這個(gè)值改大一些。
             
              大概知道ulimit這個(gè)命令是相關(guān)的,上google搜索了一下,大多數(shù)說(shuō)的很含糊,也沒(méi)有統(tǒng)一說(shuō)一下,經(jīng)過(guò)兩個(gè)小時(shí)看了不少文章終于弄清楚ulimit相關(guān)的一些配置問(wèn)題。
             
              我們可以用ulimit -a來(lái)查看所有限制值,我只關(guān)心文件句柄數(shù)量的問(wèn)題
             
              open files (-n) 1024
             
              這個(gè)就是限制數(shù)量
             
              這里,有很多ulimit的文章都說(shuō)的很含糊,究竟這個(gè)1024是系統(tǒng)的限制,還是用戶(hù)的限制呢。其實(shí),這個(gè)是用戶(hù)限制來(lái)的,完整的說(shuō)法,應(yīng)該是當(dāng)前用戶(hù)準(zhǔn)備要運(yùn)行的程序的限制。
             
              1、這個(gè)限制是針對(duì)單個(gè)程序的限制
             
              2、這個(gè)限制不會(huì)改變之前已經(jīng)運(yùn)行了的程序的限制
             
              3、對(duì)這個(gè)值的修改,退出了當(dāng)前的shell就會(huì)消失
             
              比如說(shuō),我先運(yùn)行了一個(gè)程序a,然后通過(guò)ulimit修改了限制為2048,然后運(yùn)行b,然后退出了shell再登錄,然后運(yùn)行c.那就只有b可以打開(kāi)2048個(gè)句柄。
             
              如果我們需要改變整體的限制值,或者我們運(yùn)行的程序是系統(tǒng)啟動(dòng)的,應(yīng)該怎么處理呢
             
              其中一個(gè)方法,是想ulimit修改命令放入/etc/profile里面,但是這個(gè)做法并不好
             
              正確的做法,應(yīng)該是修改/etc/security/limits.conf
             
              里面有很詳細(xì)的注釋?zhuān)热?br /> 
              * soft nofile 2048
             
              * hard nofile 32768
             
              就可以將文件句柄限制統(tǒng)一改成軟2048,硬32768
             
              這里涉及另外一個(gè)問(wèn)題,什么是軟限制,什么是硬限制
             
              硬限制是實(shí)際的限制,而軟限制,是warnning限制,只會(huì)做出warning
             
              其實(shí)ulimit命令本身就有分軟硬設(shè)置,加-h就是硬,加-s就是軟
             
              默認(rèn)顯示的是軟限制,如果修改的時(shí)候沒(méi)有加上的話(huà),就是兩個(gè)一起改
             
              配置文件最前面的一位是domain,設(shè)置為星號(hào)代表全局,另外你也可以針對(duì)不同的用戶(hù)做出不同的限制
             
              修改了,重新登錄用ulimit一開(kāi)就立刻生效了,不過(guò)之前啟動(dòng)過(guò)的程序要重新啟動(dòng)才能使用新的值。我用的是centos,似乎有些系統(tǒng)需要重啟才能生效。
             
              ulimit其實(shí)就是對(duì)單一程序的限制
             
              那系統(tǒng)總限制呢
             
              其實(shí)是在這里,/proc/sys/fs/file-max
             
              可以通過(guò)cat查看目前的值,echo來(lái)立刻修改
             
              另外還有一個(gè),/proc/sys/fs/file-nr
             
              只讀,可以看到整個(gè)系統(tǒng)目前使用的文件句柄數(shù)量
             
              查找文件句柄問(wèn)題的時(shí)候,還有一個(gè)很實(shí)用的程序lsof 
              可以很方便看到某個(gè)進(jìn)程開(kāi)了那些句柄
             
              也可以看到某個(gè)文件/目錄被什么進(jìn)程占用了。

            posted on 2011-09-21 01:07 大龍 閱讀(1660) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲精品国产自在久久| 久久精品国产精品亚洲人人| 欧美成a人片免费看久久| 88久久精品无码一区二区毛片| 久久久久女人精品毛片| 久久婷婷激情综合色综合俺也去| 人妻无码精品久久亚瑟影视 | 浪潮AV色综合久久天堂| 亚洲香蕉网久久综合影视| 亚洲人成伊人成综合网久久久| 欧美精品九九99久久在观看| 久久精品成人欧美大片| 欧美熟妇另类久久久久久不卡| 久久不见久久见免费视频7| 99久久人妻无码精品系列蜜桃| 久久夜色精品国产亚洲| 狠狠久久综合| 国产偷久久久精品专区| 999久久久无码国产精品| 久久精品国产亚洲网站| 欧美性猛交xxxx免费看久久久| 一本久久免费视频| 国内精品久久人妻互换| 久久99热精品| 亚洲国产综合久久天堂| 无码AV中文字幕久久专区| 久久久久久狠狠丁香| 亚洲国产精品成人久久蜜臀| 99久久精品免费看国产一区二区三区| 国产成人久久精品一区二区三区 | 久久一日本道色综合久久| 99国产欧美精品久久久蜜芽 | 亚洲乱亚洲乱淫久久| 四虎影视久久久免费观看| 久久99精品久久只有精品| 久久国产香蕉一区精品| 国产精品无码久久久久久| 一本久道久久综合狠狠躁AV| 老司机国内精品久久久久| 国产精品一区二区久久精品涩爱| 日本精品久久久中文字幕|