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 / 问题

问题[io](unix)

Martin Hope
pmor
Asked: 2024-02-01 20:45:34 +0800 CST

GNU 并行:为什么诊断输出看起来像顺序执行而不是并行执行?

  • 6

设想:

$ cat libs.txt
lib.a
lib1.a

$ cat t1a.sh
f1()
{
        local lib=$1
        stdbuf -o0 printf "job for $lib started\n"
        sleep 2
        stdbuf -o0 printf "job for $lib done\n"
}
export -f f1
cat libs.txt | SHELL=$(type -p bash) parallel --jobs 2 f1

调用及输出:

$ time bash t1a.sh
job for lib.a started
job for lib.a done
job for lib1.a started
job for lib1.a done

real    0m2.129s
user    0m0.117s
sys     0m0.033s

这里我们看到 的执行f1确实是并行的 ( real 0m2.129s)。

但是,诊断输出看起来执行是连续的。

我期望得到以下诊断输出:

job for lib.a started
job for lib1.a started
job for lib.a done
job for lib1.a done

为什么诊断输出看起来像顺序执行而不是并行执行?

如何修复诊断输出,使其看起来像并行执行?

io
  • 1 个回答
  • 34 Views
Martin Hope
ChennyStar
Asked: 2023-09-13 21:15:18 +0800 CST

I/O 错误,但运行 badblocks 后一切又恢复正常:这怎么可能?

  • 7

太长了;

硬盘似乎已损坏。无法格式化分区(mkfs.ext4I/O 错误),即使使用新创建的 GPT 表也是如此。SMART 测试显示一些错误。我正想把光盘扔掉。在此之前,出于好奇,我进行了全面的badblocks测试。大惊喜:它没有检测到任何坏块!回到GParted,创建了一个GPT表+几个分区。现在一切正常!做了什么badblocks?

完整的故事

我试图弄清楚刚刚发生的事情:我正打算扔掉 HDD,因为我无法在其上创建分区,并且 SMART 显示了一些错误。在扔掉磁盘之前,我只是想玩一下badblocks,然后...大惊喜:badblocks似乎已经修复了我的磁盘!我什至不知道它可以做到这一点!所以我现在很高兴,我确实可以使用我的磁盘,它工作正常,但我仍在试图弄清楚刚刚发生了什么!

这是我已经好几年没用过的 4TB 希捷硬盘了。我将其插入 SATA ↔ USB 适配器(适配器工作正常,我将它与其他几个 HDD 一起使用)。Wirh GParted 我创建了一个新的 GPT 分区表,然后创建了一个分区。无法进行到底,出现mkfs.ext4I/O 错误:

(...)
Allocating group tables: done
Writing inode tables: done
Creating journal (131072 blocks): done
Writing superblocks and filesystem accounting information: 0/895
mke2fs 1.46.2 (28-Feb-2021)
mkfs.ext4: Input/output error while writing out and closing file system

我尝试了几次,使用不同的 USB 适配器、不同的 USB 电缆、不同的 USB 端口。从来没有工作过。

然后我做了一个 SMART 简短测试:

# smartctl -t short -C /dev/sde
(...)

# smartctl -a /dev/sde
(...)
Num  Test_Description    Status                  Remaining  LifeTime(hours)  LBA_of_first_error
# 1  Short captive       Completed: read failure       90%       528         191105024
(...)

显然硬盘似乎有缺陷,对吧?所以我本来打算扔掉它,但badblocks之前做了一个测试:

# badblocks -wvs -t random -b 4096 /dev/sde
Checking for bad blocks in read-write mode
From block 0 to 976754645
Testing with random pattern: done                                                 
Reading and comparing: done                                                 
Pass completed, 0 bad blocks found. (0/0/0 errors)

测试持续了大约19个小时(4TB磁盘),没有出现任何错误。我很惊讶 !

回到GParted,创建了一个新的GPT表,一些分区,一切都很顺利。

我最终做了一些我习惯做的复制测试,以检查磁盘的性能,一切看起来都很正常(复制大文件时为 155MB/s R/W)。

还做了另一个 SMART 简短测试,completed without error这次是:

# smartctl -t short -C /dev/sde
(...)

# smartctl -a /dev/sde
(...)
Num  Test_Description    Status                  Remaining  LifeTime(hours)  LBA_of_first_error
# 1  Short captive       Completed without error       00%       549         -
# 2  Short captive       Completed: read failure       90%       528         191105024
(...)

有人能理解吗?就好像运行badblocks以某种方式修复了我的硬盘一样。这怎么可能?甚至应该badblocks这样做吗?

注意:如果需要,可以提供更多信息(完整的 SMART 输出和完整的 GParted 结果)

io
  • 1 个回答
  • 18 Views
Martin Hope
Richard Buchmann
Asked: 2022-05-18 06:13:03 +0800 CST

如何使用 systemd 限制 IO 带宽?

  • 2

我正在尝试限制服务(或进程/命令)的 IO 使用。(硬件设备上的 IO 读/写限制,不适用于网络。)

我从 systemd 找到了 IOAccounting:

systemd-run --scope --user -p "IOReadBandwidthMax=/dev/zero 1M" -p "IOAccounting=true" \
    time dd if=/dev/zero count=1 bs=100M of=/tmp/foo conv=fdatasync

systemd-run --scope --user -p "IOWriteBandwidthMax=/dev/sdd 1M" -p "IOAccounting=true" \
    time dd if=/dev/zero count=1 bs=100M of=/tmp/foo conv=fdatasync

该命令快速结束并报告 200/300 MB/s。当我运行命令时,结果完全相同,没有 systemd-run 包装器。

我还尝试编写没有 systemd-run 的 systemd 服务:IO 带宽限制不起作用。

你有什么建议吗?

systemd io
  • 1 个回答
  • 357 Views
Martin Hope
Aquarius Power
Asked: 2022-01-13 15:13:15 +0800 CST

htop 从哪里为一个没有 root 的当前用户进程收集 IO 读/写数据?

  • 1

我找不到一种方法来捕获htop有关 IO_RATE IO_READ_RATE IO_WRITE_RATE 的单个进程的输出。

我需要它(最后几秒钟的 IO(或仅 1 秒),而不是整体累积的 IO)来确定进程是否无法正常运行以自动重启它。

我不能使用iotop它,因为它需要 root,这会使我的工作流程复杂化,主要是因为它显然是不必要的。

我尽我所能,/proc/$PID/...但没有发现我可以使用的关于 IO 的字节数。不是它不在那里,只是我找不到它。

因此,一种通过管道获取htop输出的方法也可以作为一种解决方法,但这不是我要问的。

我已经可以获取top大约 %CPU 的输出,但这还不够,我在top.

下面,其他地方的每个答案都是关于 iotop(否)或 htop(无法捕获输出)或其他没有帮助的应用程序,所以我决定问这个问题:
monitor IO of a running user's executable file read/write
https:// stackoverflow.com/questions/469159/an-htop-like-tool-to-display-disk-activity-in-linux(如果atop可以,我仍然不明白如何......)

io proc
  • 1 个回答
  • 117 Views
Martin Hope
Bruce Johnson
Asked: 2021-10-05 07:56:07 +0800 CST

是否有可以以恒定吞吐量读写磁盘的工具?

  • 1

我正在寻找一种能够以恒定的目标吞吐量(例如 3Mb/s)读写数据的工具,而不是将 I/O 系统推到极限。然后,我打算在这种相当稳定的 I/O 活动发生时监控各种指标。我看过类似的工具stress,fio但似乎它们更倾向于最大吞吐量。对于可以执行此类操作的工具的任何建议将不胜感激。谢谢。

benchmark io
  • 2 个回答
  • 73 Views
Martin Hope
Keith Bennett
Asked: 2021-09-17 13:39:50 +0800 CST

如何使用 < 和 > 为同一文件覆盖 shell 中的文件?[复制]

  • 1
这个问题在这里已经有了答案:
“确保不在同一管道中读取和写入同一文件” [重复] 3 个答案
去年关闭。

当我这样做my_script < filename.txt > filename.txt时,文件将被覆盖并截断。

在 Unix 命令行上是否有某种方法可以指定重定向不是同时进行的,即在输入完成之前输出不会开始?

我正在尝试编写一个读取文件的实用程序,并根据命令行选项重新生成并覆盖它。我意识到我可以在程序中添加不使用标准输入/标准输出的支持,但我喜欢重定向的灵活性和便利性。

io
  • 2 个回答
  • 1511 Views
Martin Hope
xiaojueguan
Asked: 2021-09-07 23:43:06 +0800 CST

update-initramfs:/boot/initrd.img-4.15.0-112-generic 失败,为 1

  • 1

说明:

当我运行 dist-upgrade 时,我遇到了以下详细信息的问题

1 not fully installed or removed.
After this operation, 0 B of additional disk space will be used.
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
    LANGUAGE = "en_US:",
    LC_ALL = (unset),
    LC_CTYPE = "UTF-8",
    LC_TERMINAL = "iTerm2",
    LANG = "en_US.UTF-8"
    are supported and installed on your system.
perl: warning: Falling back to a fallback locale ("en_US.UTF-8").
locale: Cannot set LC_CTYPE to default locale: No such file or directory
locale: Cannot set LC_ALL to default locale: No such file or directory
Setting up initramfs-tools (0.136ubuntu6.6) ...
update-initramfs: deferring update (trigger activated)
Processing triggers for initramfs-tools (0.136ubuntu6.6) ...
update-initramfs: Generating /boot/initrd.img-4.15.0-112-generic
W: Possible missing firmware /lib/firmware/ast_dp501_fw.bin for module ast
Error 24 : Write error : cannot write compressed block
E: mkinitramfs failure lz4 -9 -l 24
update-initramfs: failed for /boot/initrd.img-4.15.0-112-generic with 1.
dpkg: error processing package initramfs-tools (--configure):
 installed initramfs-tools package post-installation script subprocess returned error exit status 1
Errors were encountered while processing:
 initramfs-tools
E: Sub-process /usr/bin/dpkg returned an error code (1)

任何人都可以解决这个问题吗?

apt io
  • 1 个回答
  • 2705 Views
Martin Hope
a_random_user
Asked: 2019-07-03 02:42:09 +0800 CST

一个 IO 写操作可以比一个进程更长寿?

  • 0

据我所知,当进程写入文件时,它会启动系统调用。在所需的信息中,它需要一个指向用户空间缓冲区的指针,其中填充了要写入的数据。

考虑一个场景,其中有一个进程产生两个线程。一个线程执行系统调用以写入 10MB。另一个线程执行触发分段错误的无效内存访问,而操作系统正在处理 IO 请求。在这种情况下写请求会发生什么?特别是,我保证写操作不会发生或在进程内存释放之前完成?如果 io 请求只是一个 64 位整数,答案会改变吗?

linux io
  • 1 个回答
  • 60 Views
Martin Hope
Căcărău
Asked: 2019-05-04 22:42:48 +0800 CST

为什么 hexdump 会尝试读取 EOF?

  • 5

从终端运行时,hexdump不会对行首的单个做出反应^D,就像cat, od,bc等一样,除非还没有输入:

prompt% hexdump -C
<control-D>
prompt% hexdump -C
hello
<control-D><control-D> # a single ^D won't do
00000000  68 65 6c 6c 6f 0a                                 |hello.|
00000006

我可以在 fedora 28 和 debian 9 上重现它。尽管hexdump由bsdmainutilsDebian 提供,但在 bsd 上不会发生这种情况。

这只是一个错误吗?是否有任何其他已知的程序表现出这种行为?

linux io
  • 2 个回答
  • 528 Views
Martin Hope
Redirect
Asked: 2019-05-03 14:59:31 +0800 CST

了解文件流和文件描述符

  • 1

对于额外的上下文,我之前问过这个问题,并认为我理解了一些事情,但现在不明白了。

我知道echo忽略stdin. 我知道stdin,stderr并且stdout存在,并且在这种情况下,我不知道除了这些之外的“事物”存在。

那么,如果echoignores stdin,它从哪里获得输入呢?似乎stdin,stdout并stderr没有讲述整个故事。

io stdout
  • 1 个回答
  • 547 Views

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