Bash腳本debug攻略

来源:https://www.cnblogs.com/wbourne/archive/2022/07/14/16468485.html
-Advertisement-
Play Games

初學Bash時, 我從未想過去debug Bash腳本, 也從未想過Bash腳本也能debug. 隨著技術的增長, 寫的腳本越來越複雜, 使用echo列印日誌來調試腳本的方式越來越捉襟見肘了. 直到某天 通讀了一遍Bash Reference Manual, 才發現Bash腳本也是可以debug的. ...


初學Bash時, 我從未想過去debug Bash腳本, 也從未想過Bash腳本也能debug. 隨著技術的增長, 寫的腳本越來越複雜, 使用echo列印日誌來調試腳本的方式越來越捉襟見肘了. 直到某天
通讀了一遍Bash Reference Manual, 才發現Bash腳本也是可以debug的. 下麵就介紹三種debug Bash腳本的方式.

1. debug某個腳本

執行腳本有兩種方式, 一是bash script.sh的方式, 二是./script.sh的方式. 通過第一種方式執行腳本時, 加上-x選項即可debug腳本.
輸出的結果中, 以+開頭的行就是debug輸出的信息.

$ cat test.sh
#!/bin/bash

echo "Time: $(date)"
echo "User: $USER"
echo "Home: $HOME"

$ bash -x test.sh 
++date
+echo 'Time: Mon 11 Jul 2022 11:29:37 PM CST'
Time: Mon 11 Jul 2022 11:29:37 PM CST
+echo 'User: wbourne '
User: wbourne 
+echo 'Home: /home/wbourne '
Home: /home/wbourne 

2. debug特定腳本

前面說過執行腳本有兩種方式, 那如果是用第二種方式執行腳本如何debug呢? 修改腳本的shabangbash -x即可. 每次執行腳本就會輸出debug信息.
此方式適合debug某個特定的腳本, 執行腳本時會預設輸出debug信息; 而上面的第一種方式則適合debug任何腳本.

$ cat test.sh
#!/bin/bash -x

echo "Time: $(date)"
echo "User: $USER"
echo "Home: $HOME"

$ ./test.sh 
++date
+echo 'Time: Mon 11 Jul 2022 11:32:52 PM CST'
Time: Mon 11 Jul 2022 11:32:52 PM CST
+echo 'User: wbourne '
User: wbourne
+echo 'Home: /home/wbourne '
Home: /home/wbourne

請註意: 如果修改腳本的shabang為bash -x, 又以bash script.sh的方式執行腳本, 會發生什麼? 居然沒有輸出debug信息!!!
設置shabang表示設置一個預設解釋器, 如果沒有指定解釋器才會使用shabang中寫的解釋器. 以bash script.sh的方式執行腳本則指定瞭解釋器為bash, 所以不會有debug信息.

$ bash test.sh 
Time: Mon 11 Jul 2022 11:32:12 PM CST
User: wbourne 
Home: /home/wbourne 

3. debug腳本某一部分

如果腳本比較長, 我們之關心其中一部分, 就可以使用Bash內置命令set來debug部分腳本.
set -x表示開啟debug, set +x表示關閉debug

$ cat test.sh
#!/bin/bash

echo "Time: $(date)"
set -x
echo "User: $USER"
set +x
echo "Home: $HOME"

$ ./test.sh 
Time: Mon 11 Jul 2022 11:33:43 PM CST
+echo 'User: wbourne '
User: wbourne 
+set +x
Home: /home/wbourne 

4. PS4

既然是debug, 那肯定要詳細才好. 上述debug只不過是輸出了變數值而已, 是不是可以顯示更多信息? 當然是可以的, debug信息的提示符是環境變數PS4, 預設為+, 我們可以更改PS4的值, 使其輸出腳本名, 函數名, 行數等更詳細的信息. 這個提示符還是綠色的哦!

$ echo $PS4
+

$ export PS4='+\e[01;32m[${BASH_SOURCE}:${FUNCNAME[0]}:${LINENO}]\e[00m'

$ bash -x test.sh 
++[test.sh::3]date
+[test.sh::3]echo 'Time: Mon 11 Jul 2022 11:35:08 PM CST'
Time: Mon 11 Jul 2022 11:35:08 PM CST
+[test.sh::4]echo 'User: wbourne '
User: wbourne 
+[test.sh::5]echo 'Home: /home/wbourne '
Home: /home/wbourne 

5. 參考


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 面向對象(上) java面向對象學習三條主線 * 1.java類及類的成員:屬性、方法、構造器、代碼塊、內部類 * 2.面向對象的三大特征:封裝,繼承,多態 * 3.其他關鍵字:this,super,static,final,abstract,interface,package,import等 面向 ...
  • 在做某個業務時,需要將文件傳輸到另一臺伺服器,指定使用sftp方式;於是在網上找到jsch包使用,原先代碼大致如下: 1 ChannelSftp channelSftp = null; 2 try { 3 JSch jsch = new JSch(); 4 jsch.getSession("ftpU ...
  • 1.== 既可以比較基本類型也可以比較引用類型。對於基本類型就是比較值,對於引用類型就是比較記憶體地址 2.equals的話,它是屬於java.lang.Object類裡面的方法,如果該方法沒有被重寫過預設也是==;我們可以看到String等類的equals方法是被重寫過的,而且String類在日常開 ...
  • 今天用Flask + MySQL 實現用戶註冊,登錄和登出。 一、實戰場景 Flask 框架實現用戶的註冊,登錄和登出。 二、主要知識點 flask_login 插件使用 SQLAlchemy 基礎操作 用戶基礎類設計 Flask 讀取配置文件 藍圖註冊與使用 wtforms 表單提交數據 wtfo ...
  • 1. 函數 在python中,函數通過def關鍵字、函數名和可選的參數列表定義。通過return關鍵字返回值。我們舉例來說明如何定義和調用一個簡單的函數: >>> def foo(): ... return 1 >>> foo() 1 方法體(當然多行也是一樣的)是必須的,通過縮進來表示,在方法名的 ...
  • 作者:小牛呼嚕嚕 | https://xiaoniuhululu.com 電腦內功、JAVA底層、面試相關資料等更多精彩文章在公眾號「小牛呼嚕嚕 」 Java對象究竟是什麼? 對象:對象是類的一個實例,有狀態和行為。 類:類是一個模板,它描述一類對象的行為和狀態。 例如 人 是一個類 其狀態有:姓 ...
  • Map下的介面及其多個實現類 1.Map :雙列數據存儲key-value對的數據, 類似於高中弄的函數:y=f(x) (1)HashMap:作為map的主要實現類,線程不安全的,效率高,存儲在null的key-value ①存儲在null的key和value如下圖所示 LinkedHashMap: ...
  • 前言:前言不重要,linq入門常用的語法,linq語法可以用來寫操作集合、資料庫表集合等等幾乎所有集合類型的操作。下麵就寫幾個案例(以List集合來做的),看代碼和運行結果即可。 本文演示環境:VS2022 + .NET 6 1、創建一個.NET 6.0的控制台項目,用來演示測試和輸出。 2、然後新 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...