Gebruik van het Exec-commando in Shell-scripts

Gebruik Van Het Exec Commando In Shell Scripts



Deze handleiding gaat dieper in op het exec-commando en het gebruik ervan in shell-scripts.

Vereisten:

Om de stappen uit te voeren die in deze handleiding worden gedemonstreerd, hebt u de volgende onderdelen nodig:

  • Een functioneel Linux-systeem. Leer meer over een Ubuntu VM opzetten met VirtualBox .
  • Toegang tot een niet-rootgebruiker met sudo-rechten .
  • Een geschikte teksteditor. Bijvoorbeeld: Waarom / NeoVim , Nano , Sublieme tekst , VSCodium , enz.

Het Exec-commando

Het exec-commando is op zichzelf geen apart hulpmiddel:







$ welke exec



Het is eerder een intern commando van de Bash-shell:



$ man exec





Zoals de beschrijving van de man-pagina suggereert, vervangt exec de shell als er een commando is opgegeven, zonder dat er een extra proces wordt voortgebracht. Er zijn een handvol opties beschikbaar die het gedrag van de exec-opdracht wijzigen.



Basisgebruik

Standaard spawnt Bash bij het uitvoeren van een opdracht een subshell en splitst de opdracht.

$ echo $$ && slaap 999

$ pstree -P

Hier drukt het echo-commando de PID van de huidige shell af. De Bash-shell (PID: 978) brengt een nieuw onderliggend proces voort om te werken met het slaapcommando (PID: 8369).

Wat als we het slaapcommando uitvoeren met exec?

$ echo $$ && exec slaap 999

$ pstree -p

Het bovenliggende Bash-proces wordt vervangen door het slaapcommando. Bij succesvolle uitvoering keert het niet terug naar de shell. In plaats daarvan wordt de sessie beëindigd.

Schone omgeving

De standaard Bash-configuratie wordt geleverd met een aantal tweaks en omgevingsvariabelen. In bepaalde scenario's (bijvoorbeeld foutopsporing) wilt u misschien uw script/programma in een schone omgeving uitvoeren. Met behulp van exec kunnen we een schone shell-instantie starten in plaats van de huidige.

Gebruik eerst de opdracht printenv om alle omgevingsvariabelen weer te geven die momenteel zijn geconfigureerd:

$ printenv

Gebruik nu exec om een ​​schoon exemplaar te starten:

$ exec -C bashen

$ printenv

Lancering van een andere shell

Naast Bash en 'sh' zijn er meerdere andere shell-programma's beschikbaar, elk met hun unieke voordelen. Als een programma/script een specifieke shell vereist, kunt u exec gebruiken om de huidige Bash-shell te vervangen door de gewenste shell.

In het volgende voorbeeld vervangen we Bash door 'sh':

$ pstree -P

$ exec sch

$ pstree -P

Exec gebruiken in scripts

Nu de basis achter de rug is, kunnen we exec gaan gebruiken in onze shellscripts.

Voorbeeld 1: Werken met verschillende shells

Bekijk het volgende script:

#!/bin/bash

echo $SCHEL

echo 'echo zsh succesvol gelanceerd' > zsh.sh

exec zsh zsh.sh

Hier drukt het eerste echo-commando de huidige shell af. Standaard zou het Bash moeten zijn. Vervolgens start de opdracht exec 'zsh' om het script 'zsh.sh' uit te voeren.

Voer het volgende script uit:

$ . / test.sh

Voorbeeld 2: het bestaande proces overschrijven

Telkens wanneer een opdracht/programma wordt aangeroepen, brengt Bash een nieuw proces voort. In de meeste situaties is het geen punt van zorg. Wanneer u echter werkt met een systeem met zeer beperkte bronnen (bijvoorbeeld ingebedde hardware), kan het helpen om exec te gebruiken om het bestaande proces in het geheugen te overschrijven.

Bekijk het volgende script:

#!/bin/bash

pstree -P

exec pstree -P

echo 'Hallo Wereld'

Hier toont het eerste pstree-commando de originele lay-out van de procesboom. Zodra het exec-commando is uitgevoerd, vervangt het tweede pstree-commando de lopende shell. Het echo-commando op de laatste regel is niet uitgevoerd.

Voer het volgende script uit:

$ . / test.sh

Omdat het een onderdeel van het script was, keren we na succesvolle uitvoering terug naar de originele shell.

Aangezien het exec-commando de bovenliggende shell vervangt door een ander commando/programma, wordt alle code daarna ongeldig. Wees voorzichtig wanneer u ze in uw scripts gebruikt.

Voorbeeld 3: Loggen

De Bash-shell biedt 3 unieke bestandsdescriptors voor elk lopend programma/script:

  • STDOUT (1): standaard uitvoer, slaat normale uitvoer op
  • STDERR (2): standaardfout, slaat foutmeldingen op
  • STDIN (0): standaard invoer

Met behulp van exec kunnen we deze bestandsdescriptors omleiden naar een andere locatie, bijvoorbeeld: logbestanden. Het kan helpen bij het debuggen en loggen in het algemeen.

Over het algemeen gebruikt u de omleidingsoperator als u STDOUT en STDERR naar een logbestand wilt omleiden:

$ echo $$ | tee test.log

$ monnik 2 >& 1 | tee test.log

Deze methode vereist omleiding op elk punt dat u wilt loggen. Om dit probleem op te lossen, kunnen we de opdracht exec gebruiken om een ​​permanente omleiding voor de shell-sessie te maken. Bekijk het volgende voorbeeld:

#!/bin/bash

> test.log

exec 1 >> test.log

exec 2 >& 1

echo 'Hallo Wereld'

verkeerde_opdracht

Hier maakt de eerste regel een leeg logbestand aan. De eerste exec-opdracht zorgt voor een permanente omleiding van STDOUT naar het logbestand. De tweede exec-opdracht leidt STDERR om naar STDOUT.

Met deze opstelling worden alle uitvoer en foutmeldingen in het logbestand gedumpt:

$ . / test.sh

$ kat test.log

Wat als het script continue logboekvermeldingen genereert?

#!/bin/bash

> test.log

exec 1 >> test.log

exec 2 >& 1

terwijl WAAR

Doen

echo $WILLEKEURIG

slaap 5

klaar

Hier, in het eerste deel, maken we een permanente omleiding van STDOUT en STDERR naar ons logbestand. De oneindige while-lus voert het echo-commando uit totdat we het geforceerd sluiten met 'Ctrl + C'. De variabele $RANDOM is een speciale variabele die elke keer dat deze wordt gebruikt een willekeurige tekenreeks retourneert.

Gebruik de volgende staartopdracht om de bijgewerkte logboekinvoer te controleren:

$ staart -F test.log

Merk op dat deze omleiding alleen geldig is voor de shell-sessie.

Voorbeeld 4: invoer vanuit bestand

Net zoals we een permanente STDOUT- en STDERR-omleiding hebben gemaakt, kunnen we er ook een maken voor STDIN. Omdat STDIN echter wordt gebruikt voor invoer, is de implementatie iets anders.

In het volgende script halen we STDIN uit een bestand:

#!/bin/bash

echo 'echo' Hallo Wereld '' > invoer

exec < invoer

lezen lijn 1

evalueren $lijn_1

Hier, in de eerste regel, gebruiken we echo om de inhoud van het input_string-bestand te genereren met behulp van omleiding. De opdracht exec leidt de inhoud van input_string om naar STDIN van de huidige shell-sessie. Na het lezen van de string gebruiken we eval om de inhoud van $line_1 te behandelen als een shell-code.

Voer het volgende script uit:

$ . / test.sh

Conclusie

We bespraken het exec-commando in Bash. We hebben ook de verschillende manieren getoond om het in scripts te gebruiken. We demonstreerden het gebruik van exec om met meerdere shells te werken, geheugenefficiënte scripts te maken en de bestandsdescriptors om te leiden.

Dit is slechts een klein deel van wat kan worden bereikt met behulp van de Bash-scripting. Meer informatie over Bash-scripting van de Bash-programmering subcategorie.

Veel rekenplezier!