AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 704097
Accepted
jsaak
jsaak
Asked: 2022-05-28 08:01:43 +0800 CST2022-05-28 08:01:43 +0800 CST 2022-05-28 08:01:43 +0800 CST

根据 strace,getcwd() 怎么可能有时需要半秒钟?

  • 772

据我了解,它甚至不涉及文件系统。那么,这可能是什么原因,使用strace -T:

     0.481441 getcwd("/home/user/web/url.com/public_html", 4096) = some number

我正在使用 Linux 4.9.30。

系统有一些奇怪的滞后,我想识别它。cpu,iowait,load,memory,一切似乎都正常 是kvm虚拟机,可能会有所改变。

kvm kernel
  • 2 2 个回答
  • 53 Views

2 个回答

  • Voted
  1. Marcus Müller
    2022-05-28T08:49:58+08:002022-05-28T08:49:58+08:00

    提示:sudo perf record -ag如果您安装了内核调试符号,可能会在这里为您提供有趣的信息,包括花在特定内核功能上的时间。

    无论如何,

    据我了解,它甚至不涉及文件系统。

    这是不正确的。getcwd正如linux内核实现的那样,必须检查您的cwd是否仍然存在,它所在的文件系统是否仍然挂载,并迭代到文件系统的根目录以检查该目录是否仍然可以访问。

    这可能会产生副作用,并且会因文件系统以某种方式处于被阻止的状态而延迟。

    这里最可能的罪魁祸首是内核中非常频繁的内存回收运行所持有的 RCU 锁。这可能是一个危险的驱动程序问题,但也可能是非常频繁的命名空间创建等问题。

    • 1
  2. Best Answer
    jsaak
    2022-06-12T22:19:38+08:002022-06-12T22:19:38+08:00

    我们发现,这是一个有故障的 SSD。这些是有助于识别它的命令:

    $ ioping -c 20 /home/jsaak/temp/
    min/avg/max/mdev = 1.00 ms / 5.71 ms / 29.3 ms / 7.62 ms
    
    $ fio --randrepeat=1 --ioengine=libaio --direct=1 --gtod_reduce=1 --name=fiotest --filename=testfio --bs=4k --iodepth=64 --size=32M --readwrite=randrw --rwmixread=75
      read : io=24608KB, bw=3136.8KB/s, iops=784, runt=  7845msec
      write: io=8160.0KB, bw=1040.2KB/s, iops=260, runt=  7845msec
    
    • 1

相关问题

  • /proc/net/wireless 如何是 /proc/net/dev 的“克隆”?

  • Linux Mint 内核损坏

  • Linux 内核开发人员如何处理数百万行代码的工作?他们是一种方法吗?[关闭]

  • 通过标签将根文件系统传递给linux内核

  • 以 root 用户身份访问文件系统

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve