Linux磁盘/硬盘测速,dd命令
参考:
https://blog.csdn.net/Franciz777/article/details/126779259
=================================================
概念介绍:
/dev/zero:
In Unix-like operating systems, /dev/zero is a special file that provides as many null characters (ASCII NULL, 0x00; not ASCII character "digit zero", "0", 0x30) as are read from it. One of the typical uses is to provide a character stream for overwriting information. Another might be to generate a clean file of a certain size. Using mmap to map /dev/zero to RAM is the BSD way of implementing shared memory.
Like /dev/null, /dev/zero acts as a source and sink for data. All writes to /dev/zero succeed with no other effects (the same as for /dev/null, although /dev/null is the more commonly used data sink); all reads on /dev/zero return as many NULs as characters requested.
这里需要知道的两个linux上的伪文件,/dev/zero 和 /dev/null,其中用的最多的是/dev/null,之所以说是伪文件是因为这两个确实不是真实的文件,但是却可以当做文件来用。/dev/null 就向一个“黑洞”,任何内容写入都不会被保存,因此常常被用作不保存结果时的输出重定向的文件;/dev/zero可以看做是一个字节流文件,或者看作是一个无限大的写满null的文件,把这个文件作为输入就相当于获得了无尽的null数据,这里需要知道的是null数据是ASCII码中的null码,而不是ASCII码中的0,1,2......中的0。
-----------------------------------------------
这里我们要有的测速硬盘的软件为dd,查看帮助文档:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 | (base) devil@hp:~$ dd -help dd : 不适用的选项 -- h 请尝试执行 "dd --help" 来获取更多信息。 (base) devil@hp:~$ dd -h dd : 不适用的选项 -- h 请尝试执行 "dd --help" 来获取更多信息。 (base) devil@hp:~$ dd -_help dd : 不适用的选项 -- _ 请尝试执行 "dd --help" 来获取更多信息。 (base) devil@hp:~$ dd --help 用法: dd [操作数] ... 或: dd 选项 复制文件,依照指定操作数转换并格式化。 bs=字节数 一次读写的比特数(默认:512); 会覆盖 ibs 和 obs 选项 cbs=字节数 一次转换的字节数 conv=CONVS 依照每个逗号分割的符号列表转换文件 count=块数 只将复制指定数量的输入块 ibs=字节数 一次读取的字节数(默认:512) if =文件 从指定文件而非标准输入来进行读取 iflag=标志 按照以逗号分隔的符号列表指定的方式读取 obs=字节数 一次写入指定字节数(默认:512) of=文件 写入到指定文件而非标准输出 oflag=标志 按照以逗号分隔的符号列表指定的方式写入 seek=块数 在输出开始处跳过指定的 obs 大小的块数 skip=块数 在输入开始处跳过指定的 ibs 大小的块数 status=等级 要输出到标准错误的信息等级; 'none' 将仅输出错误信息, 'noxfer' 将不输出最终传输统计信息, 'progress' 将显示周期性的传输统计信息 块数和字节数后可以带有以下的一个或多个后缀: c=1, w=2, b=512, kB=1000, K=1024, MB=1000*1000, M=1024*1024, xM=M, GB=1000*1000*1000, G=1024*1024*1024 以及相应可使用 T, P, E, Z, Y。 也可使用二进制进位前缀:如 KiB=K、MiB=M 等等。 每个 CONV 符号可能为: ascii 由 EBCDIC 码转换至 ASCII 码 ebcdic 由 ASCII 码转换至 EBCDIC 码 ibm 由 ASCII 码转换至代用的 EBCDIC 码 block 在换行符结尾的记录末尾填充空格至 cbs 对应的长度 unblock 将 cbs 大小的块中尾部的空格替换为一个换行符 lcase 将大写字符转换为小写 ucase 将小写字符转换为大写 sparse 尝试寻址(seek)而非写入全空(NUL)的输出块 swab 交换每一对输入数据字节 sync 将每个输入数据块以 NUL 空字符填充至 ibs 的大小;当配合 block 或 unblock 使用时,会以空格代替 NUL 字符来填充 excl 如果输出文件已存在则认为操作失败 nocreat 不要创建输出文件 notrunc 不要截断输出文件 noerror 读取数据发生错误后仍然继续 fdatasync 结束前将输出文件数据物理上写入磁盘 fsync 与上者类似,但也将元数据一同写入 FLAG 符号可以是: append 追加模式(仅对输出有意义;隐含了conv=notrunc) direct 使用直接I /O 存取模式 directory 除非是目录,否则操作失败 dsync 使用同步 I /O 存取模式 sync 与上者类似,但同时也对元数据生效 fullblock 为输入积累完整块(仅iflag) nonblock 使用无阻塞I /O 存取模式 noatime 不更新访问时间 nocache 请求不使用缓存。参见 oflag= sync noctty 不根据文件指派控制终端 nofollow 不跟随链接文件 count_bytes 把 'count=N' 看作字节计数(仅 iflag) skip_bytes 把 'skip=N' 看作字节计数(仅 iflag) seek_bytes 把 'seek=N' 看作字节计数(仅 oflag) 向正在运行的 'dd' 进程发送 USR1 信号可以令其向标准错误输出 I /O 统计数据并继续进行复制。 选项有: --help 显示此帮助信息并退出 --version 显示版本信息并退出 GNU coreutils 在线帮助:<https: //www .gnu.org /software/coreutils/ > 请向 <http: //translationproject .org /team/zh_CN .html> 报告任何翻译错误 完整文档 <https: //www .gnu.org /software/coreutils/dd > 或者在本地使用:info '(coreutils) dd invocation' |
------------------------------
可以看到这个软件的设置参数比较多,不过我们常用的比较少,给出必要的参数的说明:
bs=字节数 一次读写的比特数(默认:512);测试时的每次读写的数据量大小。
if=文件 从指定文件而非标准输入来进行读取。从哪个文件里读数据。
of=文件 写入到指定文件而非标准输出。把数据写入到哪个文件。
FLAG参数:
direct 使用直接I/O 存取模式。数据写入给硬盘缓存队列后操作系统即可视为数据已经写入硬盘,由硬盘自身的电路和软件绝对如何真正分批的写入硬盘的磁盘,该方式是最高效的硬盘写入方式,现实运行中也是使用该种方式的。
dsync 使用同步 I/O 存取模式。每次操作写入数据都是需要把数据直接写入硬盘磁盘的,不在硬盘缓存中驻留,由于硬盘每次写入都是有一定延迟的(尤其机械硬盘寻道操作比较耗时),这种硬盘对操作系统的每次写入操作都直接响应后写入磁盘而不是存储在硬盘缓存的方式会极大的降低磁盘的写入效率。
sync 与上者类似,但同时也对元数据生效。和dsync同步类似,只不过对磁盘文件的元数据更新也是使用该种同步方式,写入效率几乎和dsync一样低。
写入测试:
(4k数据大小,10k次写入)
dd bs=4k count=10k if=/dev/zero of=/tmp/test oflag=direct
dd bs=4k count=10k if=/dev/zero of=/tmp/test oflag=dsync
dd bs=4k count=10k if=/dev/zero of=/tmp/test oflag=sync
(1M数据大小,10k次写入)
dd bs=1M count=10k if=/dev/zero of=/tmp/test oflag=direct
dd bs=1M count=10k if=/dev/zero of=/tmp/test oflag=dsync
dd bs=1M count=10k if=/dev/zero of=/tmp/test oflag=sync
读取测试:
(4k数据大小,10k次写入)

(1M数据大小,10k次写入)

=================================================
posted on 2023-02-21 12:53 Angry_Panda 阅读(696) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
2018-02-21 centos7 中将执行文件python链接为python3后 如何保证 yum 功能不受影响
2018-02-21 Centos7环境下安装python3.6.4 并与python2共存
2018-02-21 使用 某款基于Socks5协议的代理软件 一段时间后 被封锁掉IP的一些技术思考