執行shell指令碼有以下幾種方式
1、相對路徑方式,需先cd到指令碼路徑下
複製代碼 代碼如下:
[root@banking tmp]# cd /tmp
[root@banking tmp]# ./ceshi.sh
指令碼執行成功
2、絕對路徑方式
複製代碼 代碼如下:
[root@banking tmp]# /tmp/ceshi.sh
指令碼執行成功
3、bash命令調用
複製代碼 代碼如下:
[root@banking /]# bash /tmp/ceshi.sh
指令碼執行成功
4、. (空格) 相對或絕對方式
複製代碼 代碼如下:
[root@banking /]# . /tmp/ceshi.sh
說下幾種方式的區別
第一種和第二種沒有什麼區別,兩種方式都需要提前賦予指令碼以執行許可權。
第三種是把指令碼當做bash的調用來處理,所以,指令碼不需要有執行許可權就可以執行。
前三種方式都是在當前shell中開啟一個子shell來執行指令碼內容,當指令碼內容結束,則子shell關閉,回到父shell中。
第四種是使指令碼內容在當前shell裡執行,而不是單獨開子shell執行。
開子shell與不開子shell的區別就在於,環境變數的繼承關係,如在子shell中設定的當前變數,不做特殊通道處理的話,父shell是不可見的。
而在當前shell中執行的話,則所有設定的環境變數都是直接生效可用的。
驗證:
複製代碼 代碼如下:
[root@banking /]# cat /tmp/ceshi.sh
top
1、前三種執行方式下的pstree顯示
複製代碼 代碼如下:
├─sshd─┬─sshd───bash───bash───top
│ └─sshd───bash───pstree
2、第四種執行方式下的pstree顯示
複製代碼 代碼如下:
├─sshd─┬─sshd───bash───top
│ └─sshd───bash───pstree
3、驗證環境變數設定的繼承關係及可見關係
建立兩個指令碼,father.sh和subshell.sh。其中father.sh調用subshell.sh
複製代碼 代碼如下:
[root@banking /]# cat /tmp/father.sh
v_ceshi='father'
#-------父shell中定義變數
echo "以子shell方式呼叫指令碼"
/tmp/subshell.sh
echo "輸出v_ceshi值為${v_ceshi}"
echo ""
echo "在當前shell中執行指令碼"
. /tmp/subshell.sh
echo "輸出v_ceshi值為${v_ceshi}"
[root@banking /]#
[root@banking /]# cat /tmp/subshell.sh
v_ceshi=son
[root@banking /]#
執行結果為
複製代碼 代碼如下:
[root@banking /]# /tmp/father.sh
以子shell方式呼叫指令碼
輸出v_ceshi值為father
在當前shell中執行指令碼
輸出v_ceshi值為son