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

首頁 > 開發 > Linux Shell > 正文

Bash腳本內置的調試方法技巧

2020-07-27 19:07:08
字體:
來源:轉載
供稿:網友

用 Bash 寫的腳本也可以進行調試,和 Python,Perl 等解釋型語言一樣。新建一個名為 servinfo 的腳本并增加可執行權限:

復制代碼 代碼如下:

$ vi servinfo

#!/bin/bash

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

$ chmod +x servinfo


用 bash -x 來調試上述腳本,Bash 先打印出每行腳本,再打印出每行腳本的執行結果:
復制代碼 代碼如下:

$ 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]}: '

執行結果為:
復制代碼 代碼如下:

$ 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

如果只想調試其中幾行腳本的話可以用 set -x 和 set +x 把要調試的部分包含進來:
復制代碼 代碼如下:

#!/bin/bash

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


這個時候可以直接運行腳本,不需要執行 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

如果要調試一個非常復雜的 Bash 腳本的話,建議用專門的調試工具,比如:bashdb

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁德市| 仪征市| 米脂县| 桐柏县| 阳信县| 安阳市| 会理县| 开阳县| 松溪县| 额敏县| 新邵县| 沅江市| 南漳县| 丽水市| 西城区| 桐庐县| 辽阳县| 漾濞| 蕉岭县| 图们市| 安顺市| 长治市| 宁乡县| 青河县| 宣武区| 繁昌县| 米脂县| 西充县| 周至县| 拜城县| 苗栗市| 乐清市| 辽源市| 横山县| 曲水县| 宿松县| 牡丹江市| 广水市| 定边县| 临泽县| 沧源|