V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
richarddingcn
V2EX  ›  问与答

求助 为啥 lsof | wc -l 出来的结果远大于 ulimits -n 设置的 kernel 参数?

  •  
  •   richarddingcn · Jan 14, 2022 · 1920 views
    This topic created in 1574 days ago, the information mentioned may be changed or developed.

    最近测试服务器的 websocket 总是主动断开导致 client 报 1006 我们怀疑是 file descriptor 的数量超了 现在服务器的 ulimits -n 设置成了 100001 但是 lsof | wc -l 中显示有 20w 以上的结果 让人感觉非常疑惑 求助各位大佬能帮忙答疑解惑了

    3 replies    2022-01-14 21:15:51 +08:00
    x1596357
        1
    x1596357  
       Jan 14, 2022 via iPhone
    其他用户的加在一起?
    richarddingcn
        2
    richarddingcn  
    OP
       Jan 14, 2022 via iPhone
    @x1596357 不是 hard limit 是 100001 我查到原因了 lsof 的结果还有内存中的文件数量 超过 hard limit 正常
    hahahahahahahah
        3
    hahahahahahahah  
       Jan 14, 2022 via iPhone
    losf 命令虽然作用是"list open files",但用 lsof | wc -l 统计打开文件数上非常不准确。主要原因是:

    某些情况下,一行可能显示的是线程,而不是进程,对于多线程的情况,就会误以为一个文件被重复打开了很多次
    子进程会共享 file handler
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5267 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 01:10 · PVG 09:10 · LAX 18:10 · JFK 21:10
    ♥ Do have faith in what you're doing.