執行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