Bash腳本內(nèi)置的調(diào)試方法技巧
用 Bash 寫的腳本也可以進行調(diào)試,和 Python,Perl 等解釋型語言一樣。新建一個名為 servinfo 的腳本并增加可執(zhí)行權(quán)限:
$ vi servinfo
#!/bin/bash
echo "Hostname: $(hostname)"
echo "Date: $(date)"
echo "Kernel: $(uname -mrs)"
$ chmod +x servinfo
用 bash -x 來調(diào)試上述腳本,Bash 先打印出每行腳本,再打印出每行腳本的執(zhí)行結(jié)果:
$ bash -x servinfo
++ hostname
+ echo 'Hostname: vpsee'
Hostname: vpsee
++ date
+ echo 'Date: Thu Sep 3 19:33:48 SAST 2009'
Date: Thu Sep 3 19:33:48 SAST 2009
++ uname -mrs
+ echo 'Kernel: Linux 2.6.18-128.4.1.el5 i686'
Kernel: Linux 2.6.18-128.4.1.el5 i686
如果想同時打印行號的話,可以在腳本開頭加上:
export PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
執(zhí)行結(jié)果為:
$ bash -x servinfo
+ export 'PS4=+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
+ PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
++4:5:: hostname
+4:5:: echo 'Hostname: vpsee'
Hostname: vpsee
++4:6:: date
+4:6:: echo 'Date: Thu Sep 3 19:42:06 SAST 2009'
Date: Thu Sep 3 19:42:06 SAST 2009
++4:7:: uname -mrs
+4:7:: echo 'Kernel: Linux 2.6.18-128.4.1.el5 i686'
Kernel: Linux 2.6.18-128.4.1.el5 i686
如果只想調(diào)試其中幾行腳本的話可以用 set -x 和 set +x 把要調(diào)試的部分包含進來:
#!/bin/bash
echo "Hostname: $(hostname)"
set -x
echo "Date: $(date)"
set +x
echo "Kernel: $(uname -mrs)"
這個時候可以直接運行腳本,不需要執(zhí)行 bash -x 了:
$ ./servinfo
Hostname: vpsee
++ date
+ echo 'Date: Thu Sep 3 19:46:53 SAST 2009'
Date: Thu Sep 3 19:46:53 SAST 2009
+ set +x
Kernel: Linux 2.6.18-128.4.1.el5 i686
如果要調(diào)試一個非常復(fù)雜的 Bash 腳本的話,建議用專門的調(diào)試工具,比如:bashdb
相關(guān)文章
如何使用 Shell 腳本執(zhí)行 .NET Core 應(yīng)用
這篇文章主要介紹了如何使用 Shell 腳本執(zhí)行 .NET Core 應(yīng)用,幫助大家更好的理解和使用shell 腳本,感興趣的朋友可以了解下2020-09-09Shell腳本監(jiān)控網(wǎng)站頁面正常打開情況
這篇文章主要介紹了Shell腳本監(jiān)控網(wǎng)站頁面正常打開情況的代碼分享,本文實現(xiàn)監(jiān)控打開情況,若出錯則發(fā)送郵件通知,需要的朋友可以參考下2014-12-12shell 遞歸遍歷目錄下的所有文件并統(tǒng)一改名的方法
今天小編就為大家分享一篇shell 遞歸遍歷目錄下的所有文件并統(tǒng)一改名的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06