Usi del comando Exec negli script della shell

Usi Del Comando Exec Negli Script Della Shell



Questa guida approfondisce il comando exec e il suo utilizzo negli script di shell.

Prerequisiti:

Per eseguire i passaggi illustrati in questa guida, sono necessari i seguenti componenti:

  • Un sistema Linux funzionale. Impara di più riguardo configurazione di una macchina virtuale Ubuntu utilizzando VirtualBox .
  • Accesso ad un utente non root con privilegio sudo .
  • Un editor di testo adatto. Per esempio: Perché / NeoVim , Nano , Testo sublime , VSCodio , eccetera.

Il comando Exec

Il comando exec non è uno strumento separato di per sé:







$ Quale esec



Piuttosto, è un comando interno della shell Bash:



$ Uomo esec





Come suggerisce la descrizione della pagina man, se viene specificato un comando, exec lo sostituisce con la shell, senza generare alcun processo aggiuntivo. Sono disponibili alcune opzioni che modificano il comportamento del comando exec.



Utilizzo di base

Per impostazione predefinita, ogni volta che si esegue un comando, Bash genera una subshell e crea un fork del comando.

$ eco $$ && sonno 999

$ pstree -P

Qui, il comando echo stampa il PID della shell corrente. La shell Bash (PID: 978) genera un nuovo processo figlio per lavorare con il comando sleep (PID: 8369).

Ora, cosa succede se eseguiamo il comando sleep usando exec?

$ eco $$ && esec sonno 999

$pstree -p

Il processo genitore Bash è sostituito dal comando sleep. In caso di esecuzione riuscita, non ritorna alla shell. Al contrario, la sessione viene terminata.

Ambiente pulito

La configurazione predefinita di Bash include una serie di modifiche e variabili d'ambiente. In alcuni scenari (debug, ad esempio), potresti voler eseguire il tuo script/programma in un ambiente pulito. Con l'aiuto di exec, possiamo lanciare un'istanza di shell pulita al posto di quella corrente.

Innanzitutto, utilizza il comando printenv per elencare tutte le variabili di ambiente attualmente configurate:

$ printenv

Ora, usa exec per avviare un'istanza pulita:

$ esec -C bash

$ printenv

Avvio di una shell diversa

Oltre a Bash e 'sh', sono disponibili molti altri programmi shell, ognuno con i propri vantaggi unici. Se un programma/script richiede una shell specifica, puoi utilizzare exec per sostituire l'attuale shell Bash con quella desiderata.

Nell'esempio seguente, sostituiamo Bash con 'sh':

$ pstree -P

$ esec sh

$ pstree -P

Utilizzo di Exec negli script

Con le nozioni di base, ora possiamo iniziare a utilizzare exec nei nostri script di shell.

Esempio 1: lavorare con shell diverse

Dai un'occhiata al seguente script:

#!/bin/bash

eco $SHELL

eco 'echo zsh avviato con successo' > zsh.sh

esec zsh zsh.sh

Qui, il primo comando echo stampa la shell corrente. Per impostazione predefinita, dovrebbe essere Bash. Quindi, il comando exec avvia 'zsh' per eseguire lo script 'zsh.sh'.

Esegui il seguente script:

$ . / test.sh

Esempio 2: sostituzione del processo esistente

Ogni volta che si chiama un comando/programma, Bash genera un nuovo processo. Nella maggior parte delle situazioni, non è motivo di preoccupazione. Tuttavia, quando si lavora con un sistema con risorse molto limitate (hardware incorporato, ad esempio), l'utilizzo di exec per sovrascrivere il processo esistente in memoria può essere d'aiuto.

Dai un'occhiata al seguente script:

#!/bin/bash

pstree -P

esec pstree -P

eco 'Ciao mondo'

Qui, il primo comando pstree mostra il layout originale dell'albero dei processi. Una volta eseguito il comando exec, il secondo comando pstree sostituisce la shell in esecuzione. Il comando echo sull'ultima riga non è stato eseguito.

Esegui il seguente script:

$ . / test.sh

Poiché faceva parte dello script, torniamo alla shell originale dopo l'esecuzione riuscita.

Poiché il comando exec sostituisce la shell genitore con un comando/programma diverso, qualsiasi codice successivo diventa non valido. Fai attenzione quando li usi nei tuoi script.

Esempio 3: registrazione

La shell Bash offre 3 descrittori di file univoci per qualsiasi programma/script in esecuzione:

  • STDOUT (1): output standard, memorizza l'output normale
  • STDERR (2): errore standard, memorizza i messaggi di errore
  • STDIN (0): ingresso standard

Usando exec, possiamo reindirizzare questi descrittori di file in una posizione diversa, ad esempio: file di registro. Può aiutare con il debug e la registrazione in generale.

In genere, se si desidera reindirizzare STDOUT e STDERR a un file di registro, si utilizza l'operatore di reindirizzamento:

$ eco $$ | tee test.log

$ monaco 2 >& 1 | tee test.log

Questo metodo richiede il reindirizzamento in ogni punto che si desidera registrare. Per risolvere questo problema, possiamo utilizzare il comando exec per creare un reindirizzamento permanente per la sessione della shell. Dai un'occhiata al seguente esempio:

#!/bin/bash

> test.log

esec 1 >> test.log

esec 2 >& 1

eco 'Ciao mondo'

comando_errato

Qui, la prima riga crea un file di registro vuoto. Il primo comando exec stabilisce un reindirizzamento permanente di STDOUT al file di registro. Il secondo comando exec reindirizza STDERR a STDOUT.

Con questa configurazione, tutti gli output e i messaggi di errore vengono scaricati nel file di registro:

$. / test.sh

$ gatto test.log

Cosa succede se lo script genera voci di registro continue?

#!/bin/bash

> test.log

esec 1 >> test.log

esec 2 >& 1

Mentre VERO

Fare

eco $ CASUALE

sonno 5

Fatto

Qui, nella prima parte, creiamo un reindirizzamento permanente di STDOUT e STDERR al nostro file di log. Il ciclo while infinito esegue il comando echo fino a quando non lo chiudiamo forzatamente usando 'Ctrl + C'. La variabile $RANDOM è una variabile speciale che restituisce una stringa casuale ogni volta che vi si accede.

Per verificare la voce del registro di aggiornamento, utilizzare il seguente comando tail:

$ coda -F test.log

Si noti che questo reindirizzamento dura solo per la sessione della shell.

Esempio 4: Input da file

Analogamente a come abbiamo creato un reindirizzamento STDOUT e STDERR permanente, possiamo anche crearne uno per STDIN. Tuttavia, poiché STDIN viene utilizzato per l'input, l'implementazione è leggermente diversa.

Nel seguente script, prendiamo STDIN da un file:

#!/bin/bash

eco 'eco ' Ciao mondo '' > ingresso

esec < ingresso

Leggere Linea 1

eval $linea_1

Qui, nella prima riga, usiamo echo per generare il contenuto del file input_string usando il reindirizzamento. Il comando exec reindirizza il contenuto di input_string a STDIN della sessione di shell corrente. Dopo aver letto la stringa, usiamo eval per trattare il contenuto di $line_1 come un codice shell.

Esegui il seguente script:

$ . / test.sh

Conclusione

Abbiamo discusso del comando exec in Bash. Abbiamo anche mostrato i vari modi di usarlo negli script. Abbiamo dimostrato l'utilizzo di exec per lavorare con più shell, creare script efficienti in termini di memoria e reindirizzare i descrittori di file.

Questa è solo una piccola parte di ciò che può essere ottenuto utilizzando lo scripting Bash. Scopri di più sullo scripting di Bash dal Programmazione bash sottocategoria.

Buona informatica!