調試shell腳本的關鍵在于使用bash -x和set -e。一、bash -x可查看每行命令及變量展開結果,便于定位問題,亦可在腳本首行添加#!/bin/bash -x啟用調試模式。二、set -e讓腳本遇錯即停,避免錯誤擴散,但需臨時關閉時可用set +e再恢復。三、結合兩者效果更佳,既顯示執行流程又及時終止錯誤,也可動態控制調試范圍以減少日志量。
寫shell腳本時,調試是個繞不開的環節。尤其是腳本邏輯復雜或運行環境多變的時候,光靠打印echo信息效率太低。常用的調試方式就是用bash -x和set -e這兩個工具配合使用,能幫你快速定位問題。
一、用bash -x查看腳本執行過程
bash -x 是最直觀的調試方式,它會在執行腳本時把每一行命令以及變量展開后的結果都打印出來,適合用來觀察腳本實際是怎么跑的。
比如你有個腳本叫 test.sh,直接運行:
bash -x test.sh
你會看到類似這樣的輸出:
+ echo 'Hello World' Hello World
前面的 + 表示當前執行的命令。這樣你就能看到哪一行出了問題,或者變量有沒有被正確替換。
如果你不想每次都加 -x,也可以在腳本第一行加上:
#!/bin/bash -x
這樣腳本一運行就會自動進入調試模式。
二、用set -e讓腳本出錯就退出
默認情況下,Shell腳本遇到錯誤會繼續往下執行,這有時會讓你誤以為整個流程是成功的,其實中間某個關鍵步驟已經失敗了。
這時候可以用 set -e,它的作用是:一旦某條命令返回非0狀態碼(也就是出錯了),整個腳本立刻停止執行。
用法很簡單,在腳本開頭加上:
#!/bin/bash set -e
比如你寫了這么一段:
rm /tmp/nonexistent_file.txt echo "File removed"
如果文件不存在,rm 會報錯但腳本還是會繼續輸出”File removed”。加上 set -e 后,腳本會在rm失敗時立即退出,避免后續邏輯出錯。
不過要注意的是,有些命令即使失敗也想繼續執行,比如你想判斷某個命令是否存在:
if ! command -v some_tool >/dev/null; then echo "some_tool not found" fi
這種情況下要臨時關閉 -e,可以這樣寫:
set +e command -v some_tool >/dev/null result=$? set -e
這樣就不會因為命令失敗而中斷腳本。
三、結合使用更有效
單獨用 -x 可以看執行流程,單獨用 -e 可以防止錯誤擴散。兩者結合起來調試效果更好。
你可以同時啟用它們,比如:
#!/bin/bash -x set -e
或者在腳本中分開寫:
#!/bin/bash set -x set -e
這樣腳本運行時既能看到每一步的執行情況,又能在出錯時及時停下來。非常適合用于CI/CD腳本、部署腳本等對可靠性要求較高的場景。
有時候你只想在部分代碼段開啟 -e 或者 -x,也可以動態控制,比如:
set -x # 開啟調試 # 這里是一些關鍵操作 set +x # 關閉調試
這種方式可以減少日志量,只關注你想看的部分。
基本上就這些。調試Shell腳本不難,關鍵是用好工具,理清邏輯。bash -x和set -e雖然簡單,但搭配起來非常實用。