部分的なSMARTテストを使用したいので、各範囲のLBAサイズが必要です。
ディスクの最大LBAを決定する方法は? (では5で割ります。)
答え1
そしてsmartctl
オプションの自己評価max
、キーワードを使用して、選択性テストに使用される最大LBAを決定できます。
# smartctl -t select,0-max /dev/sda
smartctl 7.1 2019-12-30 r5022 [x86_64-linux-5.9.11-arch2-1] (local build)
Copyright (C) 2002-19, Bruce Allen, Christian Franke, www.smartmontools.org
=== START OF OFFLINE IMMEDIATE AND SELF-TEST SECTION ===
Sending command: "Execute SMART Selective self-test routine immediately in off-line mode".
SPAN STARTING_LBA ENDING_LBA
0 0 537234767
Drive command "Execute SMART Selective self-test routine immediately in off-line mode" successful.
Testing has begun.
したがって、この場合は537234767(合計537234768を含む)です。
これは、背面が印刷したセクタの数と同じですparted
。ただし、疑いを避けるために、以下を使用してsmartctl
値を取得することをお勧めします。
また、これを中止するために使用できるセルフテストも開始されますsmartctl -X
。
答え2
Linuxを使用していると仮定すると(現在のようにtune2fs
)、オペレーティングシステムに表示されるディスクとパーティションのサイズはで確認できます/proc/partitions
。例えば
# head -3 /proc/partitions
major minor #blocks name
8 0 976762584 sda
この#blocks
フィールドは1024バイトのブロック数なので、512バイトのブロック数はその2倍です。
# awk '$4 == "sda" { print $3 * 2; } ' < /proc/partitions
1953525168
fdisk
hdparm -i
セクタ数を表示することもできます。
# fdisk -lu /dev/sda | head -1
Disk /dev/sda: 931.5 GiB, 1000204886016 bytes, 1953525168 sectors
# hdparm -i /dev/sda |grep LBAsects
CurCHS=16383/16/63, CurSects=16514064, LBA=yes, LBAsects=1953525168
別のアプローチは、Perlを使用してブロックデバイスの終わりを見つけ、オフセットを照会することです。
# perl -le '$a = sysseek(STDIN, 0, 2); print $a / 512' < /dev/sda
1953525168
またはSMARTテストが予定されていますので、次のようにお問い合わせくださいsmartctl
。
# smartctl -i /dev/sda |grep '^User Capacity:'
User Capacity: 1,000,204,886,016 bytes [1.00 TB]
# smartctl -i /dev/sda |awk '/^User Capacity: / { gsub(",", "", $3); print $3 / 512; }'
1953525168
答え3
sudo tune2fs -l /dev/sdX1
以下を含む多くの情報を印刷しますblock count
。
benraid@OMV:/srv$ sudo tune2fs -l /dev/sdk1
tune2fs 1.44.5 (15-Dec-2018)
Filesystem volume name: Elements
Last mounted on: <not available>
Filesystem UUID: e58521dc-7ac6-4096-8339-42830ceee05d
Filesystem magic number: 0xEF53
Filesystem revision #: 1 (dynamic)
Filesystem features: has_journal ext_attr resize_inode dir_index filetype extent 64bit flex_bg sparse_super large_file huge_file dir_nlink extra_isize metadata_csum
Filesystem flags: signed_directory_hash
Default mount options: user_xattr acl
Filesystem state: clean
Errors behavior: Continue
Filesystem OS type: Linux
Inode count: 427261952
Block count: 3418087163
Reserved block count: 0
Free blocks: 3390863340
Free inodes: 427261941
First block: 0
Block size: 4096
Fragment size: 4096
Group descriptor size: 64
Reserved GDT blocks: 418
Blocks per group: 32768
Fragments per group: 32768
Inodes per group: 4096
Inode blocks per group: 256
Flex block group size: 16
Filesystem created: Wed Dec 2 20:57:48 2020
Last mount time: n/a
Last write time: Wed Dec 2 21:09:13 2020
Mount count: 0
Maximum mount count: -1
Last checked: Wed Dec 2 20:57:48 2020
Check interval: 0 (<none>)
Lifetime writes: 103 GB
Reserved blocks uid: 0 (user root)
Reserved blocks gid: 0 (group root)
First inode: 11
Inode size: 256
Required extra isize: 32
Desired extra isize: 32
Journal inode: 8
Default directory hash: half_md4
Directory Hash Seed: 9bccaff2-62b7-45c9-876b-b011f5e8c6b9
Journal backup: inode blocks
Checksum type: crc32c
Checksum: 0x526fb02e
また、興味深いのは、/proc/partitions
LBAの数に4を掛けた値を印刷するようです。おそらくブロックサイズ(4096)に関連している可能性があります。
benraid@OMV:/srv$ cat /proc/partitions
major minor #blocks name
8 0 2930266584 sda
8 1 2930265543 sda1
8 48 2930266584 sdd
8 49 2930265543 sdd1
8 80 2930266584 sdf
8 81 2930265543 sdf1
8 32 2930266584 sdc
8 33 2930265543 sdc1
8 64 39082680 sde
8 65 35221504 sde1
8 66 1 sde2
8 69 3858432 sde5
8 16 2930266584 sdb
8 17 2930265543 sdb1
8 96 2930266584 sdg
8 97 2930265543 sdg1
8 112 11718885376 sdh
8 113 11718884335 sdh1
8 128 9766436864 sdi
8 129 9766435823 sdi1
8 144 11718885376 sdj
8 145 11718884335 sdj1
8 160 13672349696 sdk
8 161 13672348655 sdk1
ilkkachuが自分の意見で指摘したように、パーティション内のLBAの数は、ハードドライブ全体の正しいスペースにまたがっていません。ただし、smartctl -t select,0-$size
ジョブに表示されているサイズだけが必要な場合はまったく問題ありません。smartctl
どちらもゼロから始まり、ディスクの端で終わります。