¿Cómo exporto la información del disco duro y del chasis desde mi NAS usando un script?
Productos Aplicables
NAS (QTS / QuTS hero)
Escenario
Si utiliza un NAS QNAP con una unidad de expansión, puede que desee exportar información detallada sobre todos los discos duros instalados, como la marca, el modelo y el número de serie, para documentación o inventario. Aunque esta información aparece en la interfaz gráfica, los usuarios avanzados pueden recuperar y exportar estos detalles de los discos usando la línea de comandos a través de SSH. Esto es útil para la automatización o para llevar un inventario de sus activos de TI.
Procedimiento
- Habilitar acceso SSH en su NAS QNAP.
Nota: Habilitar SSH puede introducir riesgos de seguridad. Asegúrese de usar contraseñas fuertes y deshabilite SSH cuando no esté en uso. - Conéctese a su NAS a través de SSHusando un cliente SSH (como PuTTY o Terminal).
- Use el
hdd_id.sh
script proporcionado para exportar la información del disco:- Descargue o cree el script:Guarde el siguiente contenido como
hdd_id.sh
en su NAS:#!/bin/sh # Uso: ./hdd_id.sh todos los gabinetes, separados por tabulaciones (a stdout) ./hdd_id.sh --csv todos los gabinetes, escribir en
- -DiskList.csv ./hdd_id.sh 1 solo enc_id=1, separados por tabulaciones ./hdd_id.sh --csv 1 solo enc_id=1, escribir en - -DiskList.csv CSV=0 if [ "$1" = "--csv" ]; then CSV=1 shift fi if [ -n "$1" ]; then ENC_LIST="$1" else ENC_LIST=$(hal_app --se_enum 2>/dev/null | awk ' /^=/{next} NF==0{next} /(^|[[:space:]])enc_id($|[[:space:]])/ { hdr=1; next } hdr && $1 ~ /^[0-9]+$/ { print $1 } ' | sort -n | uniq) fi [ -z "$ENC_LIST" ] && { echo "No se encontró enc_id de gabinete."; exit 1; } OUTFILE="" DELIM="\t" if [ $CSV -eq 1 ]; then HOSTNAME=$(uname -n 2>/dev/null) [ -z "$HOSTNAME" ] && HOSTNAME="NAS" DATESTR=$(date +%Y%m%d) OUTFILE="${HOSTNAME}-${DATESTR}-DiskList.csv" DELIM="," echo "Gabinete,Slot,Marca,Modelo,Serial" > "$OUTFILE" fi for ENC in $ENC_LIST; do NAME=$(hal_app --se_get_jbod_display_name enc_id=$ENC 2>/dev/null) [ -z "$NAME" ] && NAME="ENC_${ENC}" hal_app --pd_enum enc_id=$ENC 2>/dev/null | awk -v name="$NAME" -v D="$DELIM" -v csv="$CSV" -v out="$OUTFILE" ' /^=/{next} NF==0{next} !hdr && /(^|[[:space:]])port_id($|[[:space:]])/ && /vendor/ && /model/ && /serial_no/ { for(i=1;i<=NF;i++){ if($i=="port_id") pid=i if($i=="vendor") bid=i if($i=="model") mid=i if($i=="serial_no") sid=i } hdr=1; next } hdr && $1 ~ /^[0-9]+$/ && pid>0 && bid>0 && mid>0 && sid>0 { line = name D $(pid) D $(bid) D $(mid) D $(sid) if (csv==1) { print line >> out } else { print line } } ' done - Hacer el script ejecutable:
chmod +x hdd_id.sh
- Ejecute el script según sea necesario:
./hdd_id.sh
— Lista todas las cajas, muestra datos separados por tabulaciones en el terminal../hdd_id.sh --csv
— Lista todas las cajas, genera un archivo CSV llamado<HOST>-<YYYYMMDD>-DiskList.csv.
./hdd_id.sh 1
— Lista solo la caja conenc_id=1
, separado por tabulaciones../hdd_id.sh --csv 1
— Lista solo la cajaenc_id=1
, genera un archivo CSV.
- Ejemplo de salida:
ENC_03TOSHIBAMC04ACA300E85G9XXXXFLVA ENC_06SeagateST8000VX010-2ZR188WPV0XYZZ ENC_07SeagateST8000VX010-2ZR188WPV0ZZZZ ENC_08SeagateST8000VX010-2ZR188WPVXXXR5 TR-004-N0011SeagateST4000NE001-2MA101WS24ZZZB TR-004-N0012SeagateST4000NE001-2MA101WS24XXXY
Cada línea contiene:Nombre de la caja,Ranura,Marca,Modelo,Serie.
- Descargue el archivo exportado(si usa
--csv
) desde su NAS usando File Station o SMB/CIFS.
- Descargue o cree el script:Guarde el siguiente contenido como