在Shell腳本中調用另一個腳本的三種方式講解

今天小編就爲大家分享一篇關於在Shell腳本中調用另一個腳本的三種方式講解,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

先來說一下主要以下有幾種方式:

  • fork: 如果腳本有執行權限的話,path/to/foo.sh。如果沒有,sh path/to/foo.sh。
  • exec: exec path/to/foo.sh
  • source: source path/to/foo.sh

fork

fork 是最普通的, 就是直接在腳本里面用 path/to/foo.sh 來調用 foo.sh 這個腳本,比如如果是 foo.sh 在當前目錄下,就是 ./foo.sh。運行的時候 terminal 會新開一個子 Shell 執行腳本 foo.sh,子 Shell 執行的時候, 父 Shell 還在。子 Shell 執行完畢後返回父 Shell。 子 Shell 從父 Shell 繼承環境變量,但是子 Shell 中的環境變量不會帶回父 Shell。

exec

exec fork 不同,不需要新開一個子 Shell 來執行被調用的腳本. 被調用的腳本與父腳本在同一個 Shell 內執行。但是使用 exec 調用一個新腳本以後, 父腳本中 exec 行之後的內容就不會再執行了。這是 exec source 的區別.

source

fork 的區別是不新開一個子 Shell 來執行被調用的腳本,而是在同一個 Shell 中執行. 所以被調用的腳本中聲明的變量和環境變量, 都可以在主腳本中進行獲取和使用。

其實從命名上可以感知到其中的細微區別,下面通過兩個腳本來體會三種調用方式的不同:

第一個腳本,我們命名爲 1.sh:

#!/usr/bin/env bash
A=1
echo "before exec/source/fork: PID for 1.sh = $$"
export A
echo "In 1.sh: variable A=$A"
case $1 in
    --exec)
        echo -e "==> using exec…\n"
        exec ./2.sh ;;
    --source)
        echo -e "==> using source…\n"
        . ./2.sh ;;
    *)
        echo -e "==> using fork by default…\n"
        ./2.sh ;;
esac
echo "after exec/source/fork: PID for 1.sh = $$"
echo -e "In 1.sh: variable A=$A\n"

第二個腳本,我們命名爲 2.sh

#!/usr/bin/env bash
echo "PID for 2.sh = $$"
echo "In 2.sh get variable A=$A from 1.sh"
A=2
export A
echo -e "In 2.sh: variable A=$A\n"

注:這兩個腳本中的參數 $$ 用於返回腳本的 PID , 也就是進程 ID。這個例子是想通過顯示 PID 判斷兩個腳本是分開執行還是同一進程裏執行,也就是是否有新開子 Shell。當執行完腳本 2.sh 後,腳本 1.sh 後面的內容是否還執行。

chmod +x 1.sh 2.sh 給兩個腳本加上可執行權限後執行情況:

fork

fork 方式可以看出,兩個腳本都執行了,運行順序爲1-2-1,從兩者的PID值(1.sh PID=82266, 2.sh PID=82267),可以看出,兩個腳本是分成兩個進程運行的。

exec

exec 方式運行的結果是,2.sh 執行完成後,不再回到 1.sh。運行順序爲 1-2。從pid值看,兩者是在同一進程 PID=82287 中運行的。

source

source方式的結果是兩者在同一進程裏運行。該方式相當於把兩個腳本先合併再運行。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章