本篇內(nèi)容主要講解“怎么用內(nèi)置變量調(diào)試shell腳本”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么用內(nèi)置變量調(diào)試shell腳本”吧!
成都創(chuàng)新互聯(lián)公司服務(wù)項目包括鎮(zhèn)賚網(wǎng)站建設(shè)、鎮(zhèn)賚網(wǎng)站制作、鎮(zhèn)賚網(wǎng)頁制作以及鎮(zhèn)賚網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,鎮(zhèn)賚網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到鎮(zhèn)賚省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!一般的shell腳本的調(diào)試基本都是echo 來處理遇到比較大的腳本的時候,就比較麻煩了,出了問題,還不是很好定位哪行代碼出問題了。
其實shell內(nèi)置的一些變量可以很好的解決這個問題:
$LINENO $FUNCNAME $BASH_LINENO 這幾個變量記錄了腳本當(dāng)前的執(zhí)行位置,以及正在執(zhí)行的函數(shù)。具體可以可以man 文檔頁。
實例代碼:a.sh
代碼如下:
#!/bin/bash
abc() {
echo "wo shi abc()"
echo "func: $FUNCNAME ln: $LINENO ln2:${BASH_LINENO[1]} brother: ${FUNCNAME[1]}"
}
b.sh:
代碼如下:
#!/bin/bash
../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)用的。
到此,相信大家對“怎么用內(nèi)置變量調(diào)試shell腳本”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!