用內(nèi)置變量調(diào)試shell腳本的方法
一般的shell腳本的調(diào)試基本都是echo 來處理遇到比較大的腳本的時候,就比較麻煩了,出了問題,還不是很好定位哪行代碼出問題了。
其實shell內(nèi)置的一些變量可以很好的解決這個問題:
$LINENO $FUNCNAME $BASH_LINENO 這幾個變量記錄了腳本當(dāng)前的執(zhí)行位置,以及正在執(zhí)行的函數(shù)。具體可以可以man 文檔頁。
實例代碼:a.sh
abc() {
echo "wo shi abc()"
echo "func: $FUNCNAME ln: $LINENO ln2:${BASH_LINENO[1]} brother: ${FUNCNAME[1]}"
}
b.sh:
../a.sh
abc
cdf() {
abc
}
執(zhí)行結(jié)果:
[root@node2 ~]# ./b.sh
[code]wo shi abc()
func: abc ln: 5 ln2:0 brother: main
wo shi abc()func: abc ln: 5 ln2:9 brother: cdf
我在b.sh 里寫了cdf 函數(shù)調(diào)用 abc 函數(shù) ,看到輸出的差別了吧,我們可以利用這些參數(shù)打印出代碼出錯行的位置,以及代碼出錯時,是由哪個函數(shù)調(diào)用的,等等。。。。
相關(guān)文章
利用linux的timerfd_create實現(xiàn)計時器示例分享
這篇文章主要介紹了利用linux的timerfd_create實現(xiàn)計時器示例,需要的朋友可以參考下2014-02-02
Linux中使用locate和find進(jìn)行不區(qū)分大小寫的文件搜索
在日常使用計算機的過程中,尤其是處理大量文件時,快速找到特定文件變得尤為重要,Linux系統(tǒng)提供了許多命令行工具,其中“l(fā)ocate”和“find”是兩個常用的文件搜索工具,本文給大家介紹了如何在Linux中使用locate和find進(jìn)行不區(qū)分大小寫的文件搜索2024-05-05
Linux系統(tǒng)上實現(xiàn)定時重啟Tomcat服務(wù)腳本介紹
大家好,本篇文章介紹的是Linux系統(tǒng)上實現(xiàn)定時重啟Tomcat服務(wù)腳本介紹,感興趣的同學(xué)趕緊來看看,希望可以對你起到幫助2021-11-11
shell腳本發(fā)送http請求的實現(xiàn)示例
本文主要介紹了shell腳本發(fā)送http請求的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04

