Linux 中高效編寫 Shell 指令碼的 10 個技巧

天府雲創發表於2017-06-19

Shell 指令碼程式設計 是你在 Linux 下學習或練習程式設計的最簡單的方式。尤其對 系統管理員要處理著自動化任務,且要開發新的簡單的實用程式或工具等(這裡只是僅舉幾例)更是必備技能。

本文中,我們將分享 10 個寫出高效可靠的 bash 指令碼的實用技巧,它們包括:

1、 指令碼中多寫註釋

這是不僅可應用於 shell 指令碼程式中,也可用在其他所有型別的程式設計中的一種推薦做法。在指令碼中作註釋能幫你或別人翻閱你的指令碼時瞭解指令碼的不同部分所做的工作。

對於剛入門的人來說,註釋用 # 號來定義。

# 這是一條註釋

2、 當執行失敗時使指令碼退出

有時即使某些命令執行失敗,bash 可能繼續去執行指令碼,這樣就影響到指令碼的其餘部分(會最終導致邏輯錯誤)。用下面的行的方式在遇到命令失敗時來退出指令碼執行:

# 如果命令執行失敗讓指令碼退出執行

set -o errexit

# 或

set -e

3、 當 Bash 用未宣告變數時使指令碼退出

Bash 也可能會使用能導致起邏輯錯誤的未宣告的變數。因此用下面行的方式去通知 bash 當它嘗試去用一個未宣告變數時就退出指令碼執行:

# 若有用未設定的變數即讓指令碼退出執行

set -o nounset

# 或

set -u

4、 使用雙引號來引用變數

當引用時(使用一個變數的值)用雙引號有助於防止由於空格導致單詞分割開和由於識別和擴充套件了萬用字元而導致的不必要匹配。

看看下面的例子:

#!/bin/bash
# 若命令失敗讓指令碼退出
set -o errexit
# 若未設定的變數被使用讓指令碼退出
set -o nounset
echo “Names without double quotes”
echo
names=”Tecmint FOSSMint Linusay”
for name in $names; do
echo “$name”
done
echo
echo “Names with double quotes”
echo
for name in “$names”; do
echo “$name”
done
exit 0

儲存檔案並退出,接著如下執行一下:

$ ./names.sh

在指令碼中用雙引號

在指令碼中用雙引號

5、 在指令碼中使用函式

除了非常小的指令碼(只有幾行程式碼),總是記得用函式來使程式碼模組化且使得指令碼更可讀和可重用。

寫函式的語法如下所示:

function check_root(){
command1;
command2;
}

# 或
check_root(){
command1;
command2;
}

寫成單行程式碼時,每個命令後要用終止符號:

check_root(){ command1; command2; }

6、 字串比較時用 = 而不是 ==

注意 == 是 = 的同義詞,因此僅用個單 = 來做字串比較,例如:

value1=”tecmint.com”
value2=”fossmint.com”
if [ “$value1” = “$value2” ]

7、 用 $(command) 而不是老舊的 `command` 來做代換

命令代換 是用這個命令的輸出結果取代命令本身。用 $(command) 而不是引號 `command` 來做命令代換。

這種做法也是 shellcheck tool (可針對 shell 指令碼顯示警告和建議)所建議的。例如:

user=`echo “$UID”`
user=$(echo “$UID”)

8、 用 readonly 來宣告靜態變數

靜態變數不會改變;它的值一旦在指令碼中定義後不能被修改:

readonly passwd_file=”/etc/passwd”
readonly group_file=”/etc/group”

9、 環境變數用大寫字母命名,而自定義變數用小寫

所有的 bash 環境變數用大寫字母去命名,因此用小寫字母來命名你的自定義變數以避免變數名衝突:

# 定義自定義變數用小寫,而環境變數用大寫

nikto_file=”$HOME/Downloads/nikto-master/program/nikto.pl”
perl “$nikto_file” -h  “$1”

10、 總是對長指令碼進行除錯

如果你在寫有數千行程式碼的 bash 指令碼,排錯可能變成噩夢。為了在指令碼執行前易於修正一些錯誤,要進行一些除錯。

相關文章