Linux 中高效編寫 Bash 腳本的 10 個技巧
Shell 腳本編程 是你在 Linux 下學習或練習編程的最簡單的方式。尤其對 系統管理員要處理著自動化任務,且要開發新的簡單的實用程序或工具等(這裡只是僅舉幾例)更是必備技能。
本文中,我們將分享 10 個寫出高效可靠的 bash 腳本的實用技巧,它們包括:
1、 腳本中多寫注釋
這是不僅可應用於 shell 腳本程序中,也可用在其他所有類型的編程中的一種推薦做法。在腳本中作注釋能幫你或別人翻閱你的腳本時了解腳本的不同部分所做的工作。
對於剛入門的人來說,注釋用 #
號來定義。
# TecMint 是瀏覽各類 Linux 文章的最佳站點
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)
而不是引號
來做命令代換。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 腳本,排錯可能變成噩夢。為了在腳本執行前易於修正一些錯誤,要進行一些調試。通過閱讀下面給出的指南來掌握此技巧:
本文到這就結束了,你是否有一些其他更好的 bash 腳本編程經驗想要分享?若是的話,在下面評論框分享出來吧。
作者簡介:
Aaron Kili 是一個 Linux 和 F.O.S.S(Free and Open-Source Software,自由及開放源代碼軟體)愛好者,未來的 Linux 系統管理員、Web 開發人員,目前是 TecMint 的內容創作者,他喜歡用電腦工作,且崇尚分享知識。
via: https://www.tecmint.com/useful-tips-for-writing-bash-scripts-in-linux/
作者:Aaron Kili 譯者:ch-cn 校對:wxy
本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive