lsof を使用して、プロセスが開いたファイル記述子の数を計算します。

lsof を使用して、プロセスが開いたファイル記述子の数を計算します。

Javaプロセスで開かれたファイル記述子の数を確認する必要があります。 lsofの出力長はほぼ40,000ジュールです。これは始まりに過ぎません。

COMMAND   PID     USER   FD      TYPE             DEVICE  SIZE/OFF     NODE NAME
java    12003 jboss  cwd       DIR              253,7      4096  1835012 /obcdn/Jboss/bin
java    12003 jboss  rtd       DIR              253,0      4096        2 /
java    12003 jboss  txt       REG              253,7      7336  2621459 /obcdn/java1.8/bin/java
java    12003 jboss  mem       REG              253,2    111080   171382 /usr/lib64/libresolv-2.17.so
java    12003 jboss  mem       REG              253,2     27776   133531 /usr/lib64/libnss_dns-2.17.so
java    12003 jboss  mem       REG              253,7    278078  1966631 /obcdn/Jboss/modules/system/layers/base/org/yaml/snakeyaml/main/snakeyaml-1.15.0.redhat-1.jar
java    12003 jboss  mem       REG              253,7    360979  1835896 /obcdn/Jboss/modules/system/layers/base/org/apache/james/mime4j/main/apache-mime4j-0.6.0.redhat-5.jar
java    12003 jboss  mem       REG              253,7     32957  1835471 /obcdn/Jboss/modules/system/layers/base/com/fasterxml/jackson/jaxrs/jackson-jaxrs-json-provider/main/jackson-module-jaxb-annotations-2.5.4.redhat-1.jar
java    12003 jboss  mem       REG              253,7     28742  1835469 /obcdn/Jboss/modules/system/layers/base/com/fasterxml/jackson/jaxrs/jackson-jaxrs-json-provider/main/jackson-jaxrs-base-2.5.4.redhat-1.jar
java    12003 jboss  mem       REG              253,7     16843  1835470 /obcdn/Jboss/modules/system/layers/base/com/fasterxml/jackson/jaxrs/jackson-jaxrs-json-provider

したがって、プロセスはほぼ40000個のファイル記述子を使用しているように見えますが、これは少し多すぎるようです。

open files                      (-n) 40000

私の分析を確認するために、lsofの各行出力は実際にオープンFDですか?それとも正しい数を得るために出力をgrepする必要がありますか?ありがとう

ベストアンサー1

memFDではなく.からの製品なので確認し mmap()たかったです。 、、、およびFDではありませんが、それぞれが1つずつある必要があるため、数値に大きな影響はありません。grep -v " mem "cwdrtdtxt

おすすめ記事