Precisa identificar o disco no zpool ... como?


14

Preciso substituir um disco defeituoso em um zpool no FreeNAS.

zpool status mostra

gptid/5fe33556-3ff2-11e2-9437-f46d049aaeca  UNAVAIL      0     0     0  cannot open

Como encontro o número de série desse disco?


Mais:

glabel status dá:

                                      Name  Status  Components
                             ufs/FreeNASs3     N/A  da0s3
                             ufs/FreeNASs4     N/A  da0s4
                    ufsid/4fa405ab96518680     N/A  da0s1a
                            ufs/FreeNASs1a     N/A  da0s1a
                            ufs/FreeNASs2a     N/A  da0s2a
gptid/5f3c0517-3ff2-11e2-9437-f46d049aaeca     N/A  ada1p2
gptid/60570005-3ff2-11e2-9437-f46d049aaeca     N/A  ada3p2
gptid/60ebeaa5-3ff2-11e2-9437-f46d049aaeca     N/A  ada4p2
gptid/a767b8ef-1c95-11e2-af4c-f46d049aaeca     N/A  ada6p2
gptid/61925b86-3ff2-11e2-9437-f46d049aaeca     N/A  ada9p2
gptid/4599731b-8f15-11e1-a14c-f46d049aaeca     N/A  ada10p2

Eu não vejo gptid/5fe33556lá.

E camcontrol devlistdá:

<Hitachi HDS723030BLE640 MX6OAAB0>  at scbus0 target 0 lun 0 (pass0,ada0)
<ST3000VX000-9YW166 CV13>          at scbus4 target 0 lun 0 (pass1,ada1)
<ST3000VX000-9YW166 CV13>          at scbus6 target 0 lun 0 (pass3,ada3)
<Hitachi HDS723030BLE640 MX6OAAB0>  at scbus7 target 0 lun 0 (pass4,ada4)
<ST3000DM001-9YN166 CC4C>          at scbus8 target 0 lun 0 (pass5,ada5)
<WDC WD30EZRX-00MMMB0 80.00A80>    at scbus8 target 1 lun 0 (pass6,ada6)
<WDC WD30EZRX-00MMMB0 80.00A80>    at scbus9 target 0 lun 0 (pass7,ada7)
<ST3000DM001-9YN166 CC4C>          at scbus9 target 1 lun 0 (pass8,ada8)
<Hitachi HDS723030BLE640 MX6OAAB0>  at scbus10 target 0 lun 0 (pass9,ada9)
<Hitachi HDS5C3030ALA630 MEAOA580>  at scbus11 target 0 lun 0 (pass10,ada10)
< USB Flash Memory 1.00>           at scbus12 target 0 lun 0 (pass11,da0)

Isso significa que esse ada2é o disco defeituoso?


ATUALIZAR:

OK, tenho certeza de que esse ada2é o disco defeituoso. E eu tenho minhas anotações, então eu sei qual disco é esse.

Mas parece que deixei uma reposição lá - ada0 - da última vez que estive na caixa. Posso substituir ada2 por ada0 remotamente? Até que alguém chegue ao escritório?


Então aqui a questão é mais sobre como identificar de qual disco é essa partição? (como periódicos de disco pode ser encontrado em dmesg)
Ouki

O meu mal dmesg: há o modelo de unidade, mas não o seu serial. Parece que só smartcl -ipode lhe dar esse tipo de informação. Por que você precisa, a propósito, já que depois de remover o disco do compartimento, ele está escrito na etiqueta do disco ?!
Ouki

Eu preciso do número de série, para que eu saiba qual disco extrair ... Não sei a que essa longa string gptid se refere ... costumava dizer "ada" alguma coisa, mas não mais.
Dan

2
O gptidID exclusivo do GEOM. Agora que seu disco está inoperante, você não pode obter o serial, mas ainda pode descobrir qual "adaX" deve ser retirado.
Ouki

Este é um exemplo clássico de por que as melhores práticas recomendam o uso de etiquetas GPT e incluem o número de série (ou pelo menos vários dígitos de ordem inferior) na etiqueta GPT. Dessa forma, quando o ZFS informar que um rótulo GPT falhou, você saberá exatamente que o SN do disco é. A etiqueta GPT também precisa ser fisicamente identificada na parte frontal da bandeja do disco, por isso é inequívoco qual unidade precisa ser puxada para localizar um número de série específico. Veja Domínio do ZFS por Lucas & Jude.
25919 Jim

Respostas:


14

Para obter um disco serial, é necessário que ele esteja em execução e disponível:

  • camcontrol identify <device> |grep ^serial (pode ser (S) ATA específico)
  • smartcl -i <device> |grep ^Serial
  • lendo o rótulo do disco depois de removido do gabinete

No seu caso, acho que a terceira solução é a única disponível. Então, supondo que você queira primeiro identificar o disco:

Tente primeiro a glabel status(como sua unidade não é mostrada como DOWNou REMOVED):

$ glabel status
gptid/c7868819-ddc1-11e2-8c3e-00138f3fd9c7     N/A  da0p1
gptid/c96da0bc-ddc1-11e2-8c3e-00138f3fd9c7     N/A  da2p1
  1. Você pode ver sua partição com glabel status

    Em seguida, você pode identificar facilmente o nome do dispositivo de disco (ex: da0 para a gptid/c7868819-ddc1-11e2-8c3e-00138f3fd9c7partição).

    Você pode dar uma olhada no log de inicialização do sistema /var/log/messages(aka " dmesg"):

    $ dmesg | grep ^da0
    da0 at mps0 bus 0 scbus0 target 0 lun 0
    da0: <ATA ST3000DM001-1CH1 CC26> Fixed Direct Access SCSI-6 device
    da0: 600.000MB/s transfers
    da0: Command Queueing enabled
    da0: 2861588MB (5860533168 512 byte sectors: 255H 63S/T 364801C)
    
  2. Você não pode ver sua partição com glabel status

    $ camcontrol devlist
    <ATA ST3000DM001-1CH1 CC26>        at scbus0 target 0 lun 0 (pass0,da0)
    <ATA ST3000DM001-1CH1 CC26>        at scbus0 target 4 lun 0 (pass2,da2)
    

    A partir daí, é possível identificar facilmente qual está faltando ( da1 nesse caso) e, em seguida, dar uma olhada dmesgpara identificar esse disco.

Portanto, não há solução real aqui. Só espero que isso ajude você a ver as coisas um pouco mais claras.

Para saber mais :


Veja as notas adicionadas acima ... ada2 é o disco defeituoso?
Dan

Sim. Parece que é esse.
Ouki

1
#!/bin/sh
echo
echo $(basename $0) - Mounted Drives on $(hostname)
cat /etc/version
date
echo
diskinfo="$(glabel status | tail -n +2 | awk '{split($3,a,"p"); print a[1],$1}')"
echo    "+========+==========================+==================+============================================+"
echo "| Device |     DISK DESCRIPTION     |  SERIAL  NUMBER  |                   GPTID                    |"
echo "+========+==========================+==================+============================================+"

for d in $(echo "$diskinfo" | cut -d" " -f 1)
do
   diskinf=$(diskinfo -v $d | grep '# Disk ')
   diskdescription=$(echo "$diskinf" | grep '# Disk desc' | cut -d# -f 1 | xargs)
   diskserialno=$(echo "$diskinf" | grep '# Disk ident' | cut -d# -f 1 | xargs)
   diskgptid=$(echo "$diskinfo" | grep "^$d" | cut -d" " -f 2)
   printf "| %-6s | %-24s | %-16s | %-42s |\n" "$d" "$diskdescription"     "$diskserialno" "$diskgptid"
   echo "+--------+--------------------------+------------------+--------------------------------------------+"
done

fonte


0

Você poderia tentar algo assim. Funcionou para mim:

devlist=$(sudo camcontrol devlist | awk ' { print $NF } ' | cut -f 2 -d , | sed 's/)//'g)

for device in $devlist; do sudo camcontrol identify $device | grep serial; done

que deve gerar a lista inteira de números de série.


0

Criei um script que lista todo o GPTID e o número de série do disco rígido associado e o nome do dispositivo.

#!/bin/bash

#Use smartctl to get Serial Number - else dmesg is used
USESMART=0
#save glabel status to temporary file
CACHEGLABEL=1

if  [ $CACHEGLABEL -eq 0 ]
then
GLCMD="glabel status"
else
GLTMP=/var/tmp/$0.glabel
glabel status > $GLTMP
GLCMD="cat $GLTMP"
fi

ADALOW=`ls /dev/ada[0-9] 2>/dev/null`
ADAHIGH=`ls /dev/ada[0-9][0-9] 2>/dev/null`
DALOW=`ls /dev/da[0-9] 2>/dev/null`
DAHIGH=`ls /dev/da[0-9][0-9] 2>/dev/null`
#check if all device nodes exist or skip
if  [[ $ADALOW == *ls* ]]
then
$DALOW=
fi
if  [[ $ADAHIGH == *ls* ]]
then
$ADAHIGH=
fi
if  [[ $DALOW == *ls* ]]
then
$DALOW=
fi
if  [[ $DAHIGH == *ls* ]]
then
$DAHIGH=
fi
for FILE in $ADALOW $ADAHIGH $DALOW $DAHIGH
do
DEV=${FILE##'/dev/'}
#echo -n "${DEV}: "
if  [ $USESMART -eq 0 ]
then
SERIAL=`grep $DEV: /var/log/dmesg.today |grep -i Serial | awk '{print $(NF)}'`
else
SERIAL=`smartctl -a $FILE | grep -i 'Serial Number'| awk '{print $(NF)}'`
fi
#this skips all ufs drives
GPTID=`$GLCMD |grep 2$ |grep ${DEV}p|cut -d' ' -f1`
if [ "${GPTID}x" == 'x' ]
then
GPTID="No GPTID"
fi
if [ "${SERIAL}x" == 'x' ]
then
$SERIAL="Not found"
fi
echo  ${DEV}: Serial $SERIAL \; GPTID=$GPTID
done

if  [ $CACHEGLABEL -eq 1 ]
then
rm $GLTMP
fi

-3

Supondo que você precise de um disco específico no sistema baseado em Linux, você pode obter:

ls -la /dev/disk/by-uuid/

ou pelo rótulo fs:

 ls -la /dev/disk/by-label/ 

ou por conectividade de hardware:

ls-la /dev/disk/by-path/

4
Este não é o Linux. udevé específico do Linux, como muitas /proccoisas sofisticadas ... infelizmente aqui.
Ouki

A propósito, não tenho certeza se o Linux manteria um disco inativo de udevqualquer maneira.
Ouki 04/04
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.