• <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>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
            轉自:
            http://blog.csdn.net/yetyongjin/article/details/7476860

            這兩天做asterisk的性能測試,經常碰到這樣的錯誤:“Too many open files”。

                    我們知道,Linux下,文件描述符就是一個簡單的整數值,習慣上,標準輸入(standard input)的文件描述符是 0,標準輸出(standard output)是 1,標準錯誤(standard error)是 2。POSIX 定義了STDIN_FILENO、STDOUT_FILENO 和STDERR_FILENO 來代替 0、1、2。這三個符號常量的定義位于頭文件 unistd.h。

                    文件描述符的有效范圍是0 到OPEN_MAX。那么一個進程最多到底能打開多少個文件描述符呢?下面,就以asterisk進程為例來說明。


            #ps –ef | grep asterisk


            從第二列得到asterisk的PID為19488。

            # cat /proc/19488/limits

                    紅線一行說明asterisk進程最大能打開1024個文件描述符(不包含它的子進程或創建出來的線程)。在/proc/19488/task/目錄下,詳細列出了其下的子任務的情況,每個子文件夾里同樣有一個limits文件,限定了各子任務的情況。

             

                     一個進程打開了幾個文件描述符呢?

            # ll /proc/19488/fd/


                    子目錄fd中,詳細列出了進程打開的每個文件描述符,同樣,/proc/19488/task/XXXX/fd下也會有子任務打開的文件描述符的情況。要知道有幾個,執行

            # ll /proc/19488/fd/ | wc -l

             

                    怎樣知道一個進程及其子進程和哪些文件有關聯呢?lsof可以完成這工作。請注意,關聯文件和打開文件描述符是兩個不同的概念,關聯文件的數量可能遠遠大于打開的文件描述符的數量。

            # lsof | grep asterisk | wc –l

                    也可以用父進程的PID過濾

            # lsof | grep 19488 | wc –l

                     我這里得到的值是9525

             

                     怎樣修改文件描述符的限定呢?臨時修改,可以通過ulimit。

            # ulimit -SHn 2048

             

                      但是這樣只能影響到當前的session,當終端重新連接或當前用戶退出,配置就失效了。如果想永久變更需要編輯/etc/security/limits.conf 文件,添加如下兩行:
            * hard nofile 2048
            * soft nofile 2048

             

                     內核參數對文件描述符也有限制,如果設置的值大于內核的限制,也是不行的:

                     查找file-max的內核參數:

            # sysctl -a|grep file-max

                    更改file-max的內核參數:

            # sysctl -w file-max=65535

                    Sysctl也是臨時的,要想永久生效,可以通過更改sysctl的文件,編輯/etc/sysctl.conf文件,添加或修改以下一行:

            fs.file-max=65535

             

                    需要注意的是,文件描述符的限制,不局限于這里描述的這些,還可能和進程的啟動參數、用戶的環境設置有關。當然,如果是進程BUG造成文件描述符沒有及時關閉回收,這增大限制也只是治標,根本上還得修復BUG。

                   此外,lsof會列出系統中所占用的資源,但是這些資源不一定會占用打開的文件描述符(比如共享內存,信號量,消息隊列,內存映射.等,雖然占用了這些資源,但不占用打開文件號),因此有可能出現cat /proc/sys/fs/file-max 的值小于lsof | wc -l。asterisk本身提供了一個啟動腳本,名為safe_asterisk,腳本里面就對文件描述符做了一些設置。

            posted on 2012-11-21 11:43 小果子 閱讀(3502) 評論(0)  編輯 收藏 引用 所屬分類: 學習筆記Linux
            久久精品国产99国产电影网| 久久av无码专区亚洲av桃花岛| 国产成人精品久久| 色婷婷狠狠久久综合五月| 无码人妻久久一区二区三区免费丨 | 狠狠色丁香久久综合婷婷| 97超级碰碰碰碰久久久久| 久久婷婷国产剧情内射白浆 | 成人久久久观看免费毛片| 久久国产香蕉一区精品| 性欧美大战久久久久久久久| 久久久久99精品成人片| 九九精品99久久久香蕉| 一本色道久久综合| 国产精品va久久久久久久| 少妇内射兰兰久久| 伊人久久国产免费观看视频| 久久综合久久综合久久| 色综合久久无码五十路人妻| 久久99精品国产麻豆婷婷| 狠狠色丁香久久婷婷综| 久久久久亚洲AV成人片| 久久精品亚洲AV久久久无码| 国产精品热久久无码av| 国产精品久久久久久福利69堂| 亚洲国产精品久久电影欧美| 亚洲午夜无码久久久久小说| 色婷婷噜噜久久国产精品12p| 欧美精品一区二区精品久久| 精品久久久久久国产潘金莲| 麻豆成人久久精品二区三区免费| 久久久久久久久久久久久久| 亚洲国产精品成人久久蜜臀 | 日韩AV无码久久一区二区| 久久亚洲AV成人无码| 欧美伊人久久大香线蕉综合| 热99RE久久精品这里都是精品免费| 亚洲欧美国产日韩综合久久| 少妇被又大又粗又爽毛片久久黑人| 欧美国产精品久久高清| 久久综合亚洲色HEZYO社区 |