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.
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, --allRaccogliere tutti i dati. Ciò equivale a specificare
--mdm-repository,--collect-cores,--max-cores=2,--valgrind-corese--analyse-diag-coll. -
-A, --analyse-diag-collAnalizzare 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 (quandoCOMPONENTSè omesso): Tutti i componenti dell'area utente
-b e COMPONENTI. Per la forma estesa, separare con =
Esempio
-b'mdm sds'
--collect-cores='mdm sds'
-
-d OUT_DIR, --output-dir=OUT_DIRMemorizza il bundle risultante nella directory
OUT_DIR. Default: <WORK_DIR>/scaleio-getinfo(vedere la--work-dir). -
-f, --skip-mdm-loginIgnorare la query per le credenziali di accesso a PowerFlex MDM. Utile quando l'utente ha già effettuato l'accesso manualmente.
-
-h, --helpMostrare il messaggio di aiuto ed uscire. In combinazione con
--tech, visualizza anche le opzioni per il tecnico. -
-J, --xzUtilizzare
tar/xzformato per il pacchetto raccolto anziché quello predefinitotar/gz.Ignorato se il sistematar(1)non supporta--use-compress-programoppurexz(1)non è stato trovato. -
-k NUM, --max-cores=NUMRaccogli fino a
NUMfile core da ciascun componente. Default: Tutti i file di base, implica--collect-cores -
-l, --lightGenerare 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=NUMRaccogli fino a
NUMPowerFlex traccia i file di ciascun componente. Default: Tutti i file -
-N, --skip-space-checkIgnorare la verifica dello spazio libero su disco prima della data collection.
-
-P PATH, --collect-path=PATHRaccogliere 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, --silentSoppressione dei messaggi sull'output standard.
-
-r, --mdm-repositoryRaccogliere i file del repository MDM.
-
-s, --skip-sdbgIgnorare la raccolta dell'output SDBG (debugger di diagnostica).
-
-S, --pause-core-generationSospensione 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_DIRUsa directory
WORK_DIRper i file temporanei. Default:/tmp. -
-x FILE, --output-file=FILEMemorizza il pacchetto raccolto come file denominato
FILE. Il suffisso appropriato del nome file (.tgz,.zip, e così via) viene aggiunto automaticamente. seFILEÈ-(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, --zipUtilizzare
zipformato per il pacchetto raccolto anziché quello predefinitotar/gz. Ignorato sezip(1)non viene trovato nel sistema. -
--mdm-port=PORTConnettersi all MDM utilizzando la porta
PORTper i comandi SCLI. Default:scli default behavior. -
--overwrite-output-fileSovrascrivere il file di output, se già esistente. Quando un file o una directory di output è specificato in modo esplicito (utilizzando
-xoppure-d), il comportamento predefinito è quello di rifiutare la sovrascrittura; Questa opzione ha la precedenza su questo. -
--techIncludere 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-communicationConnettersi a MDM in modalità non protetta.
-
-p PASSWORD, --password=PASSWORDUtilizzare
PASSWORDper l'accesso a PowerFlex MDM. Default: Comportamento predefinito della SCLI -
-u USERNAME, --username=USERNAMEUtilizzare
USERNAMEper l'accesso a PowerFlex MDM. Default: Comportamento predefinito della SCLI -
--ldap-authenticationAccedere a PowerFlex MDM utilizzando l'autenticazione basata su LDAP.
-
--management-system-ip=ADDRESSConnetti a
SSO/M&OatADDRESSper l'accesso a PowerFlex. Default: Comportamento predefinito della SCLI -
--p12-password=PASSWORDCrittografare l'accesso a PowerFlex
PKCS#12file che utilizzaPASSWORD. Default: Comportamento predefinito della SCLI -
--p12-path=FILEMemorizzazione delle credenziali di accesso PowerFlex
PKCS#12File asFILE. 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.
-c e COMPONENTS. Per la forma estesa, separare con =.
Esempi:
-c'mdm sds'
--generate-cores='mdm sds'
-
-C CORE_FILE, --reference-core-file=CORE_FILERaccogliere i registri e i core del prodotto relativi all'ora dell'ultima modifica (
mtime) delCORE_FILE, anziché l'ora di inizio dell'esecuzione. Implica--collect-cores -
-E REF_TIME, --event-time=REF_TIMERaccolta dei registri e dei core dei prodotti relativi a
REF_TIME, anziché l'ora di inizio dell'esecuzione. Accetta qualsiasi formato compreso dadate(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.
-b e COMPONENTS. Per la forma estesa, separare con =
Esempi:
-g'mdm sds'
--valgrind-cores='mdm sds'
-
-t MIN, --minutes-before-event=MINRaccolta di log e core di prodotto generati fino a
MINminuti prima dell'ora di riferimento. Default: 15 -
-T MIN, --minutes-after-event=MINRaccolta di log e core di prodotto generati fino a
MINminuti 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
-b e COMPONENTS. Per la forma estesa, separare con =
Esempi:
-X'mdm sds'
--collect-executables='mdm sds'
-
--keep-work-dirConservare 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 (.txtper 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/Perscli,sdc/Perdrv_cfge così via.
Nome del comando (scli,drv_cfg, e così via) viene spogliato. Il primo argomento significativo diventa il nome del file. I file vengono assegnati come suffisso pertinente,.txtper impostazione predefinita.
Esempi:
-
mdm/query_cluster.txt- Output discli --query_clustermdm/tgt_dump.txt- Output discli --debug_action --tgt_dumpsdc/query_mdms.txt- Output didrv_cfg --query_mdmssds/sdbg.txt- uscita di SDBGdumpallscreensper 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.txtsds/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-releasevar/log/messages- copia di/var/log/messagesproc/cpuinfo- copia di/proc/cpuinfo
- I file del raccoglitore di diagnostica (diag_coll) vengono copiati con
/optPrefisso 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.0, trc.1, exp.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:
- Stabilisci i candidati. Vengono enumerati tutti i file registro del prodotto e/o i core dump file per un componente.
- 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 stessomtime. I core dump file rappresentano un point-in-time, nel punto del filemtime. - Finestra temporale di applicazione (se
-Eoppure-Cspecificato). 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. - Applicare il limite di conteggio (se
-me o-kspecificato). Tra i file rimanenti, al massimoNUMsono 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-loginl'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
--loginIl 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:
tar,gzip,stat,find,awk,sed,getopt(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à INT, EXITe TERM durante la raccolta dei dati. Alla ricezione di un segnale:
- Ripristina tutti i file di configurazione sottoposti a backup (ad esempio, le impostazioni di generazione dei core).
- Pulisce le directory temporanee
- 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