国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Linux > 正文

Bash腳本內(nèi)置的調(diào)試方法技巧

2019-10-26 18:45:42
字體:
供稿:網(wǎng)友

用 Bash 寫的腳本也可以進(jìn)行調(diào)試,和 Python,Perl 等解釋型語言一樣。新建一個(gè)名為 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

如果想同時(shí)打印行號(hào)的話,可以在腳本開頭加上:
代碼如下:
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)試的部分包含進(jìn)來:
代碼如下:
#!/bin/bash

echo "Hostname: $(hostname)"
set -x
echo "Date: $(date)"
set +x
echo "Kernel: $(uname -mrs)"

這個(gè)時(shí)候可以直接運(yùn)行腳本,不需要執(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)試一個(gè)非常復(fù)雜的 Bash 腳本的話,建議用專門的調(diào)試工具,比如:bashdb

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鹤峰县| 定边县| 清苑县| 皮山县| 留坝县| 两当县| 玛曲县| 左云县| 梁山县| 红河县| 沁水县| 潞城市| 玉树县| 宣城市| 开阳县| 陇南市| 斗六市| 日土县| 改则县| 常州市| 宜兰县| 体育| 修水县| 绥中县| 洛川县| 沂南县| 株洲市| 平谷区| 密山市| 宁国市| 常熟市| 花莲市| 安西县| 惠州市| 嵩明县| 鹿邑县| 新营市| 霸州市| 青浦区| 邹城市| 石屏县|