/sys
ツリーをたどって、対応する/ dev / sdYデバイスを見つけることができます。
$ find /sys/devices | grep '/ata[0-9]\+/.*/block/s[^/]\+$' \
| sed 's@^.\+/\(ata[0-9]\+\)/.\+/block/\(.\+\)$@\1 => /dev/\2@'
より効率的な/sys
トラバーサル(lsata.shを参照):
$ echo /sys/class/ata_port/ata*/../../host*/target*/*/block/s* | tr ' ' '\n' \
| awk -F/ '{printf("%s => /dev/%s\n", $5, $NF)}'
2ディスクシステムからの出力例:
ata1 => /dev/sda
ata2 => /dev/sdb
次に、実際のハードウェアを確実に識別するために、/ dev / sdYをシリアル番号にマッピングする必要があります。例:
$ ls /dev/disk/by-id -l | grep 'ata.*sd[a-zA-Z]$'
lssci
このlssci
ユーティリティを使用して、マッピングを導出することもできます。
$ lsscsi | sed 's@^\[\([^:]\+\).\+\(/dev/.\+\)$@\1,\2@' \
| awk -F, '{ printf("ata%d => %s\n", $1+1, $2) }'
関連するlsscsi列挙は0から始まりますが、ata列挙は0から始まります。
Syslog
他に何も機能しない場合は、syslog / journalを調べてマッピングを取得できます。
/dev/sdY
デバイスはataX識別子がで列挙されているのと同じ順序で作成されkern.log
た非ディスクデバイス(ATAPI)と接続されていないリンクを無視しています。
したがって、次のコマンドはマッピングを表示します。
$ grep '^May 28 2' /var/log/kern.log.0 | \
grep 'ata[0-9]\+.[0-9][0-9]: ATA-' | \
sed 's/^.*\] ata//' | \
sort -n | sed 's/:.*//' | \
awk ' { a="ata" $1; printf("%10s is /dev/sd%c\n", a, 96+NR); }'
ata1.00 is /dev/sda
ata3.00 is /dev/sdb
ata5.00 is /dev/sdc
ata7.00 is /dev/sdd
ata8.00 is /dev/sde
ata10.00 is /dev/sdf
(上記のログメッセージは別のシステムからのものであるため、ata4は表示されないことに注意してください。)
ブートメッセージが既にローテーションされているため、私は使用/var/log/kern.log.0
してい/var/log/kern.log
ます。May 28 2
これが最後の起動時間であり、以前のメッセージを無視したいので、grepしました。
マッピングを確認するには、次の出力を確認していくつかのチェックを行います。
$ grep '^May 28 2' /var/log/kern.log.0 | \
grep 'ata[0-9]\+.[0-9][0-9]: ATA-'
May 28 20:43:26 hn kernel: [ 1.260488] ata1.00: ATA-7: SAMSUNG SV0802N, max UDMA/100
May 28 20:43:26 hn kernel: [ 1.676400] ata5.00: ATA-5: ST380021A, 3.19, max UDMA/10
[..]
そして、あなたはこの出力をhdparm
出力と比較することができます、例えば:
$ hdparm -i /dev/sda
/dev/sda:
Model=SAMSUNG SV0802N [..]
(カーネル2.6.32-31を使用)