Linux中執行Shell指令碼的方式(三種方法)
Shell 指令碼的執行方式通常有如下三種:
(1)bash script-name 或者 sh script-name;(2)path/script-name或者./script-name;(3)source script-name或者. script-name。下面,分別介紹下這三種方式的特點:
(1)bash script-name或者sh script-name
這是當指令碼檔案本身沒有可執行許可權(即檔案許可權屬性x位為-號)時常使用的方法,或者指令碼檔案開頭沒有指定直譯器時需要使用的方法。推薦使用這種方法。
(2)path/script-name或者./script-name
指在當前路徑下執行指令碼(指令碼需要有執行許可權
注意:在生產環境中,運維人員由於忘記為該指令碼設定可執行許可權,然後直接使用,導致出錯。因此,推薦第一種 bash script-name。
(3)source script-name或者. script-name
source或者“.”命令的功能是:讀入指令碼並執行指令碼,即在當前Shell中執行source或“.”載入並執行的相關指令碼檔案的命令及語句,而不是產生一個子Shell來執行檔案中的命令。
注意:這是和其他幾種執行shell方式的最大不同。
舉個栗子:
新建一個檔案test_sh.sh,不給它賦予任何可執行的許可權x。
編輯內容如下:
檔案以及檔案中內容與常見的shell不同之處在於,這裡的檔案沒有賦予可執行許可權以及在檔案內容中的首行中沒有新增#!/bin/bash。我們現在用上述介紹的幾種方式來測試下效果。
第二種方式./script-name,執行效果如下:報許可權拒絕,Permission denied,此時,我們只要更改檔案的屬性為可執行即可。
執行第一種bash script-name,效果如下:
可以成功執行,輸出:hello。但是,我們輸入命令:echo $name,發現如下:
name的值是空的。不難理解,bash script-name是產生了一個子程序shell,而我們當前的操作還在父shell中因此得不到該變數值。
執行第三種方法. test_sh.sh,效果如下:
可以成功的輸出變數的值。這是因為source script-name和. script-name是將script-name中的內容直接載入到當前的shell,因此能夠輸出當前變數的值。
剛才第二種方式我們執行失敗,現在我們通過chmod a+x script-name,然後再次執行上述命令,檢視效果:
注意:該種方式也是產生了一個子程序Shell,因此echo $name仍然找不到該變數。
補充知識點:
一個規範的Shell指令碼在第一行會指出由哪個程式(直譯器)來執行指令碼中的內容,這一行內容在Linux bash的程式設計一般為:
#!/bin/bash
或
#!/bin/sh
注意:
(1)在Shell中如果一行的第一個字母是#,則是註釋,但是上面兩個是寫在第一行,所以不是指令碼註釋行,如果寫在某個命令之後,則變成註釋行。
(2)sh為bash的軟連結,大多數情況下,指令碼的開頭使用“#!/bin/bash”和“#!/bin/sh”是沒有區別的,但更規範的寫法是在指令碼的開頭使用“#!/bin/bash”。