PowerFlex: GET_INFO - Utilità di raccolta dei pacchetti di supporto

Résumé: get_info.sh raccogliere le informazioni di diagnostica da un host PowerFlex e comprimerle in un pacchetto di supporto.

Cet article concerne Cet article ne concerne pas Cet article n’est associé à aucun produit spécifique. Toutes les versions du produit ne sont pas identifiées dans cet article.

Instructions

get_info.sh [OPZIONI]


DESCRIZIONE

get_info.sh è un utilità di diagnostica che raccoglie le informazioni di debug da un host PowerFlex (in precedenza ScaleIO) e le archivia in un pacchetto compresso per l'analisi da parte del personale di supporto.

L'utilità raccoglie dati da più fonti, tra cui:

  • Registri dei componenti PowerFlex, configurazione e file di traccia
  • Output delle query MDM/SCLI e dump di debug interno
  • Diagnostica interna dei componenti PowerFlex
  • Configurazione, registri e stato di runtime del sistema operativo
  • Inventario hardware (controller di storage, dispositivi di rete, NVMe, NVDIMM e così via)
  • Core dump (esistenti e generati opzionalmente on-demand)
  • Agente di raccolta dei dati di diagnostica (diag_coll) Statistiche

Il bundle risultante è un singolo archivio compresso (tar/gz per impostazione predefinita) che può essere trasferito al supporto PowerFlex per ulteriori analisi.

Solo un'istanza di get_info.sh può essere eseguito su un host in un determinato momento. Se non è presente spazio libero sufficiente per l'output, l'esecuzione si rifiuta (a meno che il controllo dello spazio non venga ignorato in modo esplicito).

OPZIONI

Opzioni generali

  • -a--all

    Raccogliere tutti i dati. Ciò equivale a specificare --mdm-repository--collect-cores--max-cores=2--valgrind-cores--analyse-diag-coll.

  • -A--analyse-diag-coll

    Analizzare l'agente di raccolta dei dati di diagnostica (diag coll) dati

  • -b[COMPONENTS], --collect-cores[=COMPONENTS]

    Raccogliere i core dump esistenti per l'elenco separato dallo spazio di user-land COMPONENTS. Impostazione predefinita (quando COMPONENTS è omesso): Tutti i componenti dell'area utente
     

Nota: Non deve esserci alcuno spazio tra -b e COMPONENTI. Per la forma estesa, separare con =

 

Esempio

-b'mdm sds'
--collect-cores='mdm sds'
  • -d OUT_DIR--output-dir=OUT_DIR

    Memorizza il bundle risultante nella directory OUT_DIR. Default: <WORK_DIR>/scaleio-getinfo (vedere la --work-dir).

  • -f--skip-mdm-login

    Ignorare la query per le credenziali di accesso a PowerFlex MDM. Utile quando l'utente ha già effettuato l'accesso manualmente.

  • -h--help

    Mostrare il messaggio di aiuto ed uscire. In combinazione con --tech, visualizza anche le opzioni per il tecnico.

  • -J--xz

    Utilizzare tar/xz formato per il pacchetto raccolto anziché quello predefinito tar/gz. Ignorato se il sistema tar(1) non supporta --use-compress-program oppure xz(1) non è stato trovato.

  • -k NUM--max-cores=NUM

    Raccogli fino a NUM file core da ciascun componente. Default: Tutti i file di base, implica --collect-cores

  • -l--light

    Generare un fascio di luci. Viene raccolta solo l'ultima generazione di file di registro numerati e gli eseguibili o le librerie dei componenti non vengono inclusi durante la raccolta dei core. L'utilizzo di questa opzione riduce la supportabilità e il suo utilizzo è sconsigliato.

  • -m NUM--max-traces=NUM

    Raccogli fino a NUM PowerFlex traccia i file di ciascun componente. Default: Tutti i file

  • -N--skip-space-check

    Ignorare la verifica dello spazio libero su disco prima della data collection.

  • -P PATH--collect-path=PATH

    Raccogliere il percorso aggiuntivo PATH. Sono accettati solo percorsi assoluti. Accetta caratteri jolly; I caratteri jolly devono essere racchiusi tra virgolette. Questa opzione può essere specificata più volte per raccogliere più percorsi.

  • -q--quiet--silent

    Soppressione dei messaggi sull'output standard.

  • -r--mdm-repository

    Raccogliere i file del repository MDM.

  • -s--skip-sdbg

    Ignorare la raccolta dell'output SDBG (debugger di diagnostica).

  • -S--pause-core-generation

    Sospensione della generazione core dei componenti PowerFlex durante la data collection. La configurazione originale viene ripristinata al termine della raccolta.

  • -w WORK_DIR--work-dir=WORK_DIR

    Usa directory WORK_DIR per i file temporanei. Default: /tmp.

  • -x FILE--output-file=FILE

    Memorizza il pacchetto raccolto come file denominato FILE. Il suffisso appropriato del nome file (.tgz.zip, e così via) viene aggiunto automaticamente. se FILE È (trattino), scrive il bundle sullo standard output (implica --quiet). Quando un pacchetto viene scritto nell'output standard, non viene creato alcun file di pacchetto sul disco. Default: getInfoDump.

  • -z--zip

    Utilizzare zip formato per il pacchetto raccolto anziché quello predefinito tar/gz. Ignorato se zip(1) non viene trovato nel sistema.

  • --mdm-port=PORT

    Connettersi all MDM utilizzando la porta PORT per i comandi SCLI. Default: scli default behavior.

  • --overwrite-output-file

    Sovrascrivere il file di output, se già esistente. Quando un file o una directory di output è specificato in modo esplicito (utilizzando -x oppure -d), il comportamento predefinito è quello di rifiutare la sovrascrittura; Questa opzione ha la precedenza su questo.

  • --tech

    Includere le opzioni del tecnico nell'output del messaggio della guida.

Opzioni di accesso a MDM

Le seguenti opzioni vengono passate alla SCLI --login . Il loro comportamento e i valori predefiniti sono regolati da SCLI.

  • -n--use-nonsecure-communication

    Connettersi a MDM in modalità non protetta.

  • -p PASSWORD--password=PASSWORD

    Utilizzare PASSWORD per l'accesso a PowerFlex MDM. Default: Comportamento predefinito della SCLI

  • -u USERNAME--username=USERNAME

    Utilizzare USERNAME per l'accesso a PowerFlex MDM. Default: Comportamento predefinito della SCLI

  • --ldap-authentication

    Accedere a PowerFlex MDM utilizzando l'autenticazione basata su LDAP.

  • --management-system-ip=ADDRESS

    Connetti a SSO/M&O at ADDRESS per l'accesso a PowerFlex. Default: Comportamento predefinito della SCLI

  • --p12-password=PASSWORD

    Crittografare l'accesso a PowerFlex PKCS#12 file che utilizza PASSWORD. Default: Comportamento predefinito della SCLI

  • --p12-path=FILE

    Memorizzazione delle credenziali di accesso PowerFlex PKCS#12 File as FILE. Default: Comportamento predefinito della SCLI

Opzioni per il tecnico

Le seguenti opzioni sono destinate all'utilizzo da parte dei tecnici del supporto e vengono visualizzate nel messaggio della guida solo quando --tech è specificato.

  • -c[COMPONENTS], --generate-cores[=COMPONENTS]

Generare i file core (utilizzando gcore(1)) per i processi in esecuzione dell'elenco separato dallo spazio di user-land COMPONENTS. Impostazione predefinita: tutti i componenti dell'area utente, implicano --collect-executablese richiede gdb e gcore.

 
Nota: Non deve esserci alcuno spazio tra -c e COMPONENTS. Per la forma estesa, separare con =
 

Esempi:

-c'mdm sds'
--generate-cores='mdm sds'
  • -C CORE_FILE--reference-core-file=CORE_FILE

    Raccogliere i registri e i core del prodotto relativi all'ora dell'ultima modifica (mtime) del CORE_FILE, anziché l'ora di inizio dell'esecuzione. Implica --collect-cores

  • -E REF_TIME--event-time=REF_TIME

    Raccolta dei registri e dei core dei prodotti relativi a REF_TIME, anziché l'ora di inizio dell'esecuzione. Accetta qualsiasi formato compreso da date(1). Implica --collect-cores.

  • -g[COMPONENTS], --valgrind-cores[=COMPONENTS]

Raccogliere valgrind Core dump per l'ambiente utente specificato COMPONENTS. Impostazione predefinita: tutti i componenti dell'area utente. Implica --collect-executables.

 
Nota: Non deve esserci alcuno spazio tra -b e COMPONENTS. Per la forma estesa, separare con =
 

Esempi:

-g'mdm sds'
--valgrind-cores='mdm sds'
  • -t MIN--minutes-before-event=MIN

    Raccolta di log e core di prodotto generati fino a MIN minuti prima dell'ora di riferimento. Default: 15

  • -T MIN--minutes-after-event=MIN

    Raccolta di log e core di prodotto generati fino a MIN minuti dopo l'ora di riferimento. Default: 5

  • -X[COMPONENTS], --collect-executables[=COMPONENTS]

    Raccogliere gli eseguibili dei componenti e le relative librerie condivise per l'ambiente utente specificato COMPONENTS. Default: Tutti i componenti dell'area utente

 
Nota: Non deve esserci alcuno spazio tra -b e COMPONENTS. Per la forma estesa, separare con =
 

Esempi:

-X'mdm sds'
--collect-executables='mdm sds'
  • --keep-work-dir

    Conservare la directory di lavoro temporanea generata dopo la creazione del pacchetto (pulita automaticamente).

STRUTTURA DEL FASCIO

Il bundle di output è un singolo archivio compresso.

  • La directory di primo livello del pacchetto è il nome host del sistema raccolto.
  • Gli output generali dei comandi host vanno in un server/ Sottodirectory.
    Il nome del file è <command> + <arguments> + suffisso (.txt per impostazione predefinita). Spazi sostituiti con _, caratteri non alfanumerici privati
    Esempio: server/ip_-s_addr.txt – output of ip -s addr
  • Gli output dei comandi del prodotto vanno nella sottodirectory del componente. mdm/ Per sclisdc/ Per drv_cfge così via.
    Nome del comando (sclidrv_cfg, e così via) viene spogliato. Il primo argomento significativo diventa il nome del file. I file vengono assegnati come suffisso pertinente, .txt per impostazione predefinita.

Esempi: 

    • mdm/query_cluster.txt - Output di scli --query_cluster
    • mdm/tgt_dump.txt - Output di scli --debug_action --tgt_dump
    • sdc/query_mdms.txt - Output di drv_cfg --query_mdms
    • sds/sdbg.txt - uscita di SDBG dumpallscreens per SDS
  • File dei componenti del prodotto (in contrapposizione agli output dei comandi), <component>/cfg<component>/logse così via
    Copiato dalla directory del componente con il prefisso rimosso.

Esempi: 

    • mdm/cfg/conf.txt - copia di /opt/emc/scaleio/mdm/cfg/conf.txt
    • sds/logs/trc.0 - copia di /opt/emc/scaleio/sds/logs/trc.0
  • I file del file system host vengono posizionati nel percorso del file system relativo alla root del pacchetto.

Esempi:

    • etc/os-release - copia di /etc/os-release
    • var/log/messages - copia di /var/log/messages
    • proc/cpuinfo - copia di /proc/cpuinfo
  • I file del raccoglitore di diagnostica (diag_coll) vengono copiati con /opt Prefisso spogliato, preservando la struttura interna.
    Esempio: diag_coll/logs/sar.0 - copia di /opt/diag_coll/logs/sar.0
  • I file nascosti (con prefisso punto) vengono "nascosti" rimuovendo il punto iniziale.
  • Registro di esecuzione dell'utilità, get_info_run.log, posizionato direttamente sotto il <nome> host/root

Struttura ad albero delle directory del pacchetto:

<hostname>/
|-- get_info_run.log                   Utility execution log
|-- server/                            General command output directory
|   |-- ip_-s_addr.txt
|   |-- uptime.txt
|   |-- uname_-a.txt
|   |-- ps_-elF.txt
|   |-- dmesg.txt
|   +-- ...                            (one file per collected command)
|
|-- mdm/                               PowerFlex component data (if installed)
|   |-- cfg/                           Configuration files (excl. PEM)
|   |-- logs/                          Trace and log files
|   |-- rep/                           Repository (if --mdm-repository)
|   |-- query_all.txt                  SCLI query outputs
|   |-- sdbg.txt                       SDBG screen dumps
|   +-- ...
|-- sds/
|-- pds/  
|-- dgwt/
|-- sdr/
|-- sdt/
|-- lia/
|-- sdc/
|-- gateway/
|
|-- diag_coll/                         Diagnostic data collector (if installed)
|   |-- logs/
|   |-- cfg/
|   +-- ...
|
|-- etc/                               Host files
|   |-- os-release
|   |-- sysconfig/
|   |-- network/
|   +-- ...
|-- var/
|   |-- log/
|   |   |-- messages
|   |   +-- ...
|   +-- ...
|-- proc/
|   |-- cpuinfo
|   |-- meminfo
|   +-- ...
|-- sys/
|-- ...
|
|-- scaleio-getinfo-extra/        Extra diagnostic data (if present)
+-- scaleio-getinfo-backup/       Backed-up configuration files (if any)

FILTRO DEI FILE CORE E DEI REGISTRI DI PRODOTTO

Le opzioni descritte in questa sezione controllano il modo in cui i file di registro del prodotto (chiamati anche file di traccia, ad esempio trc.0trc.1exp.0) e i core dump file vengono selezionati per l'inclusione nel pacchetto raccolto. Lo fanno definendo un tempo di riferimento, una finestra temporale intorno ad esso e i limiti di conteggio.

Quando non vengono specificate opzioni di filtro, vengono raccolti tutti i file di registro del prodotto e (se la raccolta core è abilitata) tutti i core dump file. Le opzioni di filtraggio restringono progressivamente questa selezione come descritto di seguito.

Ora di riferimento

È possibile impostare un'ora di riferimento utilizzando uno dei seguenti metodi: -E/--event-time oppure -C/--reference-core-file.

Se nessuno dei due --event-time Né --reference-core-file , non viene eseguito alcun filtro della finestra temporale: l'ora di riferimento predefinita è l'ora corrente e viene utilizzata solo per l'ordinamento basato sulla prossimità quando un limite di conteggio (-m oppure -k) (vedere Limiti di conteggio di seguito).

Se entrambi -E e -C viene visualizzato, l'ultimo elemento sulla riga di comando ha effetto.

Finestra temporale

Quando è impostata un'ora di riferimento (utilizzando --event-time oppure --reference-core-file), viene stabilita una finestra temporale intorno ad esso. L'ambito della finestra temporale può essere impostato utilizzando -t/--minutes-before-event e o -T/--minutes-after-event, che per impostazione predefinita sono rispettivamente 15 e 5 minuti. Solo i file il cui contenuto si sovrappone a questa finestra sono idonei per la raccolta.

Esempio: -E "2020-03-20 14:30" -t 10 -T 3 Raccoglie i file che coprono il periodo da 14:20:00 a 14:33:00.

--minutes-before-event e --minutes-after-event vengono ignorati quando nessuno dei due --event-time Né --reference-core-file è specificato.

Limiti di conteggio

È possibile impostare un limite di conteggio file utilizzando -m/--max-traces e -k/--max-cores, rispettivamente per i file di registro e i file core. Il limite viene misurato per componente.

Quando un numero maggiore di file NUM rientra nella finestra temporale (o è disponibile, se non è attiva alcuna finestra), vengono raccolti i file NUM più vicini all'ora di riferimento.

Quando un limite di conteggio viene utilizzato senza --event-time oppure --reference-core-file, tutti i file sono candidati (nessuna finestra temporale) e vengono selezionati i file NUM più recenti.

Logica di filtraggio

Il filtraggio dei file si applica prima alla finestra temporale, quindi al limite di conteggio:

  1. Stabilisci i candidati. Vengono enumerati tutti i file registro del prodotto e/o i core dump file per un componente.
  2. Ricavare il periodo del contenuto. Il contenuto dei file di registro del prodotto rappresenta un punto. Si considera che il periodo del contenuto inizi all'ora dell'ultima modifica del suo predecessore (mtime), o l'epoca UNIX, quando non esiste alcun predecessore; termina al file stesso mtime. I core dump file rappresentano un point-in-time, nel punto del file mtime.
  3. Finestra temporale di applicazione (se -E oppure -C specificato). I file il cui contenuto si trova interamente al di fuori della finestra vengono eliminati dalla selezione. Per i file di registro del prodotto, se nessun file è presente nella finestra, viene conservato il singolo file più vicino alla finestra in modo che il pacchetto non sia mai vuoto per un componente. Per i core dump file, non si applica alcun fallback di questo tipo.
  4. Applicare il limite di conteggio (se -m e o -k specificato). Tra i file rimanenti, al massimo NUM sono selezionati, preferendo quelli più vicini all'ora di riferimento. I file precedenti e successivi all'ora di riferimento competono equamente per la selezione.

AUTENTICAZIONE

L'utilità tenta di accedere all MDM locale se viene rilevato un processo MDM primario in ascolto sulla porta prevista (impostazione predefinita: 6611)

Le opzioni di accesso MDM vengono passate alla SCLI --login comando e sono elaborati da esso.

Se l'accesso non riesce, l'utilità viene terminata con un errore.

Quando l'accesso viene ignorato, vengono comunque tentati i comandi SCLI (per supportare scenari in cui l'utente ha effettuato l'accesso manualmente in precedenza). Dopo tre errori SCLI, viene visualizzato un avviso e tutti gli altri comandi SCLI vengono ignorati.

L'accesso viene ignorato quando:

  • Nessun processo MDM primario trovato sull host locale.
  • La colonna --skip-mdm-login l'opzione è specificata.

L'accesso ha esito negativo quando:

  • Il proprietario del processo MDM non è nell'elenco degli utenti autorizzati (impostazione predefinita: root) e l'accesso sicuro è abilitato.
  • La SCLI --login Il comando restituisce un errore (ad esempio, credenziali errate).

SPAZIO SU DISCO

I requisiti di spazio su disco per i file temporanei e il pacchetto risultante possono variare notevolmente.

L'utilità tenta di ridurre al minimo l'utilizzo temporaneo dello spazio; È limitato agli output dei comandi e alle copie del file system virtuale raccolto (/proc e /sys) file.

Il pacchetto può essere trasmesso in streaming da un host remoto con --output-file=- per ridurre al minimo l'utilizzo dello spazio su disco sull host PowerFlex. Il file del bundle viene scritto direttamente nell'output standard (stdout) durante lo streaming; Non viene creato su disco.

L'utilità stima lo spazio su disco richiesto sia per la directory di lavoro temporanea che per il bundle di output prima di raccogliere i dati.

Se lo spazio richiesto stimato supera lo spazio disponibile sui file system pertinenti, l'utilità viene terminata con un errore. Questo controllo può essere ignorato con --skip-space-check.

La directory di lavoro e la directory di output possono risiedere su file system diversi; Ognuno di essi viene controllato in modo indipendente.

I requisiti di spazio stimati vengono scritti nel file di log dell'utilità, get_info_run.log.

STATO DI USCITA

0 Completamento
1 Errore (argomenti non validi, spazio insufficiente, errore di accesso, un'altra istanza già in esecuzione, errore di generazione del pacchetto, segnale catturato e così via)

FILE

<WORK_DIR>/get_info_run.log Registro di esecuzione (incluso anche nel pacchetto)
<WORK_DIR>/scaleio-getinfo-tmp/ Directory di lavoro temporanea (pulita in caso di esito positivo)
/tmp/scaleio-getinfo/getInfoDump.tgz Posizione predefinita del bundle di output
<WORK_DIR>/scaleio-getinfo-extra/
/tmp/scaleio-getinfo-extra/
Directory aggiuntive opzionali dei dati di diagnostica
/tmp/scaleio-getinfo-backup/ Backup temporanei dei file di configurazione modificati (creati automaticamente)
/opt/emc/scaleio/ Directory di installazione di PowerFlex

AMBIENTE

Prerequisiti

  • L'utilità deve essere eseguita come root (o un utente con privilegi sufficienti per leggere i file dei componenti, eseguire comandi di diagnostica e accedere /proc/sys, e così via).
  • Utenze standard: targzipstatfindawksedgetopt(1) (migliorato), nice.
  • Opzionale: zip (ad esempio, --zip), xz (ad esempio, --xz), gdb/gcore (ad esempio, --generate-cores)

Concorrenza

Solo un'istanza di get_info.sh può essere eseguito contemporaneamente. L'utilità verifica la presenza di un'istanza in esecuzione esistente utilizzando pidof(1) e termina se viene trovata un'istanza.

Gestione del segnale

Le trap di utilità INTEXITTERM durante la raccolta dei dati. Alla ricezione di un segnale:

  1. Ripristina tutti i file di configurazione sottoposti a backup (ad esempio, le impostazioni di generazione dei core).
  2. Pulisce le directory temporanee
  3. Uscite con stato 1

Il registro di esecuzione viene conservato e il relativo percorso viene stampato con l'errore standard.

Esempi

Raccolta di un pacchetto di supporto standard:

get_info.sh

Trasmettere un pacchetto tramite una connessione SSH, senza creare un file bundle sull host PowerFlex remoto:

ssh <host> 'get_info.sh --output-file=-' > getInfoDump-<host>.tgz

Utilizzare una directory di lavoro diversa per evitare di riempire /tmp:

get_info.sh --work-dir=/var/tmp

Includere percorsi personalizzati nel pacchetto:

get_info.sh --collect-path=/opt/custom/app/logs --collect-path='/var/log/app*'

Raccogliere il core dump più recente solo per i componenti SDS e MDM:

get_info.sh --collect-cores='mdm sds' --max-cores=1

Raccogli i dati incentrati sull'ora di modifica di un file core, con una finestra temporale personalizzata:

get_info.sh --reference-core-file=/opt/emc/scaleio/sds/bin/core.1000 \
            --minutes-before-event=10 \  
            --minutes-after-event=2  
 

Produits concernés

PowerFlex rack, ScaleIO
Propriétés de l’article
Numéro d’article: 000455324
Type d’article: How To
Dernière modification: 21 May 2026
Version:  3
Trouvez des réponses à vos questions auprès d’autres utilisateurs Dell
Services de support
Vérifiez si votre appareil est couvert par les services de support.