用內(nèi)置變量調(diào)試shell腳本的方法
一般的shell腳本的調(diào)試基本都是echo 來(lái)處理遇到比較大的腳本的時(shí)候,就比較麻煩了,出了問(wèn)題,還不是很好定位哪行代碼出問(wèn)題了。
其實(shí)shell內(nèi)置的一些變量可以很好的解決這個(gè)問(wèn)題:
$LINENO $FUNCNAME $BASH_LINENO 這幾個(gè)變量記錄了腳本當(dāng)前的執(zhí)行位置,以及正在執(zhí)行的函數(shù)。具體可以可以man 文檔頁(yè)。
實(shí)例代碼: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 里寫(xiě)了cdf 函數(shù)調(diào)用 abc 函數(shù) ,看到輸出的差別了吧,我們可以利用這些參數(shù)打印出代碼出錯(cuò)行的位置,以及代碼出錯(cuò)時(shí),是由哪個(gè)函數(shù)調(diào)用的,等等。。。。
相關(guān)文章
Linux定時(shí)執(zhí)行任務(wù)at和crontab命令詳解
本篇文章主要介紹了Linux定時(shí)執(zhí)行任務(wù)at和crontab命令這兩個(gè)命令的基本用法和區(qū)別,一起學(xué)習(xí)下。2017-11-11Shell實(shí)現(xiàn)的Oracle啟動(dòng)腳本分享
這篇文章主要介紹了Shell實(shí)現(xiàn)的Oracle啟動(dòng)腳本分享,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-01-01linux 隨機(jī)密碼生成工具mkpasswd詳解及實(shí)例
這篇文章主要介紹了linux 隨機(jī)密碼生成工具mkpasswd詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-04-04Linux下如何安裝Run文件格式NVIDIA顯卡驅(qū)動(dòng)
本篇文章給大家介紹Linux下如何安裝Run文件格式NVIDIA顯卡驅(qū)動(dòng),主要設(shè)計(jì)到linux下安裝run文件格式nvidia顯卡驅(qū)動(dòng)方面的知識(shí)點(diǎn),對(duì)linux下安裝run文件格式nvidia顯卡驅(qū)動(dòng)感興趣的朋友可以參考下本文2015-10-10shell通過(guò)遍歷輸出兩個(gè)日期范圍內(nèi)所有日期的方法
這篇文章主要介紹了在shell通過(guò)遍歷輸出兩個(gè)日期范圍內(nèi)所有日期的方法,文中給出了詳細(xì)的示例代碼以及實(shí)現(xiàn)思路流程,對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-06-06學(xué)習(xí)shell腳本之前的基礎(chǔ)知識(shí)[圖文]
在學(xué)習(xí)shell腳本之前,需要你了解很多關(guān)于shell的知識(shí),這些知識(shí)是編寫(xiě)shell腳本的基礎(chǔ),所以希望你能夠熟練的掌握2013-03-03linux多線(xiàn)程編程詳解教程(線(xiàn)程通過(guò)信號(hào)量實(shí)現(xiàn)通信代碼)
這篇文章主要介紹了linux多線(xiàn)程編程詳解教程,提供線(xiàn)程通過(guò)信號(hào)量實(shí)現(xiàn)通信的代碼,大家參考使用吧2013-12-12