仮想環境において、ゲストOSからFC接続されているテープ装置を使おうとしたら、認識してないようだったので調べてみた。
結論からいうと、VMware KB2013670:「ESX/ESXi でテープデバイスが間違って ALUA デバイスとして認識されてしまう」が該当していた。
2015/12/18追記:現在は「ESXi/ESX ホストでテープ デバイスが間違って ALUA デバイスとして検出される (2090103)」で公開されている。
2020/09/28追記:「ESXi/ESX ホストでテープ デバイスが間違って ALUA デバイスとして検出される (1026157)」
対処方法も、上記KBそのままで大丈夫だった。
実際に実行した例について、以下に紹介する。
1. まず認識しているかどうかを確認する
(1)「esxcli storage core path list」を実行する。
# esxcli storage core path list <略> fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34-fc.XXXXXXXXXXXX0e:XXXXXXXXXXXX0f- UID: fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34-fc.XXXXXXXXXXXX0e:XXXXXXXXXXXX0f- Runtime Name: vmhba1:C0:T4:L0 Device: No associated device Device Display Name: No associated device Adapter: vmhba1 Channel: 0 Target: 4 LUN: 0 Plugin: (unclaimed) State: dead Transport: fc Adapter Identifier: fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34 Target Identifier: fc.XXXXXXXXXXXX0e:XXXXXXXXXXXX0f Adapter Transport Details: Unavailable or path is unclaimed Target Transport Details: Unavailable or path is unclaimed <略> fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34-fc.XXXXXXXXXXXXc8:XXXXXXXXXXXXc9- UID: fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34-fc.XXXXXXXXXXXXc8:XXXXXXXXXXXXc9- Runtime Name: vmhba1:C0:T5:L0 Device: No associated device Device Display Name: No associated device Adapter: vmhba1 Channel: 0 Target: 5 LUN: 0 Plugin: (unclaimed) State: dead Transport: fc Adapter Identifier: fc.XXXXXXXXXXXX35:XXXXXXXXXXXX34 Target Identifier: fc.XXXXXXXXXXXXc8:XXXXXXXXXXXXc9 Adapter Transport Details: Unavailable or path is unclaimed Target Transport Details: Unavailable or path is unclaimed <略> #
というような感じで「Plugin: (unclaimed)」というデバイスが認識されいている。
(2) VMware上で使える認識になっているか確認する
「esxcli storage nmp device list」を実行する。
# esxcli storage nmp device list <略> #
こちらの出力結果には出てこない。
2. 該当デバイスのSCSI inquryを調査
(1) SCSIデバイスのスキャンを実行
「esxcfg-rescan vmhba?」を実行。
今回の場合、「vmhba1」で認識されているので「esxcfg-rescan vmhba1」を実行。
(2) ログに出力されたScsiScanを確認。
# grep "ScsiScan" /var/log/vmkernel.log <略> 2012-09-21T12:52:46.210Z cpu0:2635)ScsiScan: 1098: Path 'vmhba1:C0:T0:L0': Vendor: 'HP ' Model: 'D2DBS Diagnostic' Rev: 'DIAG' 2012-09-21T12:52:46.210Z cpu0:2635)ScsiScan: 1101: Path 'vmhba1:C0:T0:L0': Type: 0x1f, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.210Z cpu3:2641)ScsiScan: 1098: Path 'vmhba1:C0:T1:L0': Vendor: 'HP ' Model: 'Ultrium 4-SCSI ' Rev: 'ED41' 2012-09-21T12:52:46.210Z cpu3:2641)ScsiScan: 1101: Path 'vmhba1:C0:T1:L0': Type: 0x1, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.211Z cpu3:2641)ScsiScan: 1582: Add path: vmhba1:C0:T1:L0 2012-09-21T12:52:46.211Z cpu3:2641)ScsiScan: 1098: Path 'vmhba1:C0:T2:L0': Vendor: 'HP ' Model: 'Ultrium 4-SCSI ' Rev: 'ED41' 2012-09-21T12:52:46.211Z cpu3:2641)ScsiScan: 1101: Path 'vmhba1:C0:T2:L0': Type: 0x1, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.212Z cpu2:2641)ScsiScan: 1582: Add path: vmhba1:C0:T2:L0 2012-09-21T12:52:46.212Z cpu1:2641)ScsiScan: 1098: Path 'vmhba1:C0:T3:L0': Vendor: 'HP ' Model: 'Ultrium 4-SCSI ' Rev: 'ED41' 2012-09-21T12:52:46.212Z cpu1:2641)ScsiScan: 1101: Path 'vmhba1:C0:T3:L0': Type: 0x1, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.213Z cpu2:2641)ScsiScan: 1582: Add path: vmhba1:C0:T3:L0 2012-09-21T12:52:46.213Z cpu3:2641)ScsiScan: 1098: Path 'vmhba1:C0:T4:L0': Vendor: 'HP ' Model: 'Ultrium 4-SCSI ' Rev: 'ED41' 2012-09-21T12:52:46.213Z cpu3:2641)ScsiScan: 1101: Path 'vmhba1:C0:T4:L0': Type: 0x1, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.213Z cpu2:2641)ScsiScan: 1582: Add path: vmhba1:C0:T4:L0 2012-09-21T12:52:46.214Z cpu1:2641)ScsiScan: 1098: Path 'vmhba1:C0:T5:L0': Vendor: 'HP ' Model: 'D2DBS ' Rev: 'EL01' 2012-09-21T12:52:46.214Z cpu1:2641)ScsiScan: 1101: Path 'vmhba1:C0:T5:L0': Type: 0x8, ANSI rev: 3, TPGS: 1 (implicit only) 2012-09-21T12:52:46.214Z cpu2:2641)ScsiScan: 1582: Add path: vmhba1:C0:T5:L0 2012-09-21T12:53:33.684Z cpu2:2745)ScsiScan: 1098: Path 'vmhba1:C0:T0:L0': Vendor: 'HP ' Model: 'D2DBS Diagnostic' Rev: 'DIAG' 2012-09-21T12:53:33.684Z cpu2:2745)ScsiScan: 1101: Path 'vmhba1:C0:T0:L0': Type: 0x1f, ANSI rev: 3, TPGS: 1 (implicit only) #
こんな感じで出力されている。
該当するものとしては、以下の3種類となる。
Vendor:「HP」、Model:「Ultrium 4-SCSI」
Vendor:「HP」、Model:「D2DBS」
Vendor:「HP」、Model:「D2DBS Diagnostic」
3. 定義の変更
(1) 該当のデバイスに「VMW_SATP_LOCAL」として動作させる設定として、まず定義を設定。
先ほどの例の場合は以下の3デバイスがある。
Vendor:「HP」、Model:「Ultrium 4-SCSI」
Vendor:「HP」、Model:「D2DBS」
Vendor:「HP」、Model:「D2DBS Diagnostic」
今回の場合は、以下のコマンドを実行した。
# esxcli storage nmp satp rule add --satp="VMW_SATP_LOCAL" --vendor="HP" --model="^Ultrium 4-SCSI*" # esxcli storage nmp satp rule add --satp="VMW_SATP_LOCAL" --vendor="HP" --model="^D2DBS*" #
なお、SCSI inquryでは文字列末尾につくスペースも重要であるが、このコマンドでは末尾のスペースは無視してくれるようである。
(2) 次に、各デバイスに対して現状、設定されている定義を解除
# esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 0 -L 0 # esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 1 -L 0 # esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 2 -L 0 # esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 3 -L 0 # esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 4 -L 0 # esxcli storage core claiming unclaim -t location -A vmhba1 -C 0 -T 5 -L 0 #
(3) 再スキャンを行い、設定した定義を適用
「esxcfg-rescan vmhba?」を実行する。
# esxcfg-rescan vmhba1 #
4. 認識が変わったことを確認
「esxcli storage nmp device list」を実行
# esxcli storage nmp device list naa.XXXXXXXXXXXXc8 Device Display Name: HP Fibre Channel Medium Changer (naa.XXXXXXXXXXXXc8) Storage Array Type: VMW_SATP_LOCAL Storage Array Type Device Config: SATP VMW_SATP_LOCAL does not support device configuration. Path Selection Policy: VMW_PSP_FIXED Path Selection Policy Device Config: {preferred=vmhba1:C0:T5:L0;current=vmhba1:C0:T5:L0} Path Selection Policy Device Custom Config: Working Paths: vmhba1:C0:T5:L0 naa.XXXXXXXXXXXX0a Device Display Name: HP Fibre Channel Tape (naa.XXXXXXXXXXXX0a) Storage Array Type: VMW_SATP_LOCAL Storage Array Type Device Config: SATP VMW_SATP_LOCAL does not support device configuration. Path Selection Policy: VMW_PSP_FIXED Path Selection Policy Device Config: {preferred=vmhba1:C0:T2:L0;current=vmhba1:C0:T2:L0} Path Selection Policy Device Custom Config: Working Paths: vmhba1:C0:T2:L0 naa.XXXXXXXXXXXX0c Device Display Name: HP Fibre Channel Tape (naa.XXXXXXXXXXXX0c) Storage Array Type: VMW_SATP_LOCAL Storage Array Type Device Config: SATP VMW_SATP_LOCAL does not support device configuration. Path Selection Policy: VMW_PSP_FIXED Path Selection Policy Device Config: {preferred=vmhba1:C0:T3:L0;current=vmhba1:C0:T3:L0} Path Selection Policy Device Custom Config: Working Paths: vmhba1:C0:T3:L0 naa.XXXXXXXXXXXX0e Device Display Name: HP Fibre Channel Tape (naa.XXXXXXXXXXXX0e) Storage Array Type: VMW_SATP_LOCAL Storage Array Type Device Config: SATP VMW_SATP_LOCAL does not support device configuration. Path Selection Policy: VMW_PSP_FIXED Path Selection Policy Device Config: {preferred=vmhba1:C0:T4:L0;current=vmhba1:C0:T4:L0} Path Selection Policy Device Custom Config: Working Paths: vmhba1:C0:T4:L0 <略> naa.XXXXXXXXXXXX08 Device Display Name: HP Fibre Channel Tape (naa.XXXXXXXXXXXX08) Storage Array Type: VMW_SATP_LOCAL Storage Array Type Device Config: SATP VMW_SATP_LOCAL does not support device configuration. Path Selection Policy: VMW_PSP_FIXED Path Selection Policy Device Config: {preferred=vmhba1:C0:T1:L0;current=vmhba1:C0:T1:L0} Path Selection Policy Device Custom Config: Working Paths: vmhba1:C0:T1:L0 #