亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

如何利用 tee 命令調(diào)試shell腳本中的管道

 更新時間:2021年05月19日 08:44:37   作者:Linux開發(fā)那些事兒  
在編寫shell腳本時,調(diào)試是個比較麻煩的事,特別是涉及到多層管道命令的時候,會產(chǎn)生多個中間結(jié)果,tee命令的作用是從標(biāo)準(zhǔn)輸入中讀取數(shù)據(jù)寫入標(biāo)準(zhǔn)輸出或文件中,利用它可以從管道中讀取中間結(jié)果并寫入本地臨時文件中,通過中間結(jié)果可以一步一步的定位到腳本的錯誤

實例

下面是一個簡單的腳本,腳本中 processid 函數(shù)的作用是查詢指定進程名字的進程ID,在管理linux服務(wù)器的過程中,這個是很常見的功能,processid 函數(shù)作用是利用多層管道命令查詢進程ID,以下是測試腳本源碼

#!/bin/sh

processid()
{
    ipid=$(ps -ef | grep -w $1 | grep -v grep | awk '{print $2}')
    echo $ipid
}

case "$1" in
    i)
       processid $2
      ;;
    *)
        echo "parameter error..$1"
      ;;
esac

執(zhí)行腳本

我們執(zhí)行這個腳本查詢 zone9_log1 的進程ID,下面是執(zhí)行的結(jié)果

[wanng@localhost ~]$ ./a.sh i zone9_log1
130530 144391 144392

為了和 zone9_log1 進程實際的進程ID對比,我們單獨執(zhí)行 ps -ef | grep -w zone9_log1 | grep -v grep | awk '{print $2}' 命令,執(zhí)行結(jié)果如下:

[wanng@localhost ~]$ ps -ef | grep -w zone9_log1 | grep -v grep | awk '{print $2}'
130530

問題

同樣的命令,確得到了不同的結(jié)果,我們在腳本中加入 tee 命令輸出管道的中間結(jié)果,調(diào)整之后的的腳本如下:

processid()
{
    ipid=$(ps -ef | grep -w $1 | tee out1 | grep -v grep | tee out2 | awk '{print $2}') | tee out3
    echo $ipid
}

case "$1" in
    i)
       processid $2
      ;;
    *)
        echo "parameter error..$1"
      ;;
esac

再次執(zhí)行腳本,本地會生成 out1 out2 out3 三個文件,記錄這管道命令的中間結(jié)果,下面是腳本執(zhí)行結(jié)果以及 out1 out2 out3 文件的內(nèi)容

[wang@localhost ~]$ ./a.sh i zone9_log1
130530 144885 144886

[wang@localhost ~]$ cat out1
wang      130530      1  0 4月24 pts/10  00:07:47 ./zone9_log1 ./zone9_log1.lua
wang       144885 109338  0 20:45 pts/8    00:00:00 /bin/sh ./a.sh i zone9_log1
wang       144886 144885  0 20:45 pts/8    00:00:00 /bin/sh ./a.sh i zone9_log1
wang       144888 144886  0 20:45 pts/8    00:00:00 grep -w zone9_log1
[wang@localhost ~]$ cat out2
wang      130530      1  0 4月24 pts/10  00:07:47 ./zone9_log1 ./zone9_log1.lua
wang       144885 109338  0 20:45 pts/8    00:00:00 /bin/sh ./a.sh i zone9_log1
wang       144886 144885  0 20:45 pts/8    00:00:00 /bin/sh ./a.sh i zone9_log1
[wang@localhost ~]$ cat out3
130530
144885
144886
[wang@localhost ~]$ 

原因

執(zhí)行腳本的時候,默認會創(chuàng)建一個新的shell(也即一個新的進程),上面的腳本 a.sh 就是在新的shell環(huán)境中執(zhí)行的。從上面的測試結(jié)果可以看出,ps -ef | grep -w zone9_log1 命令的結(jié)果中包含了執(zhí)行腳本身啟動的進程和我們要查詢的目標(biāo)進程,我們只需要過濾掉腳本本身的進程,就可以得到準(zhǔn)確的進程ID,調(diào)整之后的腳本如下(暫時先保留 tee命令輸出的中間結(jié)果):

processid()
{
    ipid=$(ps -ef | grep -w $1 | grep -v $0 | tee out1 | grep -v grep | tee out2 | awk '{print $2}') | tee out3
    echo $ipid
}

case "$1" in
    i)
       processid $2
      ;;
    *)
        echo "parameter error..$1"
      ;;
esac

上面processid函數(shù)中 grep -v $0 作用是過濾掉腳本的名字,其中 $0 表示腳本的名字 ( a.sh )

驗證

再次執(zhí)行腳本,結(jié)果如下:

[wanng@localhost ~]$ ./a.sh i zone9_log1
130530

[wanng@localhost ~]$ cat out1
wanng      130530      1  0 4月24 pts/10  00:07:51 ./zone9_log1 ./zone9_log1.lua
wanng       146170 146168  0 21:11 pts/8    00:00:00 grep -w zone9_log1
[wanng@localhost ~]$ cat out2
wanng      130530      1  0 4月24 pts/10  00:07:51 ./zone9_log1 ./zone9_log1.lua
[wanng@localhost ~]$ cat out3
130530

從上面的測試結(jié)果中看出,最后輸出的結(jié)果是正確的

總結(jié)

多層管道在shell腳本中是很常見的用法,使用起來也非常方便和高效的,但是腳本一旦出問題調(diào)試就會變得困難起來,合理的使用 tee 命令輸出管道的中間結(jié)果,可以快速的定位問題所在

以上就是如何利用 tee 命令調(diào)試shell腳本中的管道的詳細內(nèi)容,更多關(guān)于tee 命令調(diào)試shell腳本中的管道的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • mysql源碼安裝腳本分享

    mysql源碼安裝腳本分享

    這篇文章主要介紹了mysql源碼安裝的腳本,配置文件的內(nèi)容是針對mysql5.6的,需要的朋友可以參考下
    2014-03-03
  • linux?type命令用法實戰(zhàn)教程

    linux?type命令用法實戰(zhàn)教程

    type命令用來顯示指定命令的類型,它是Linux系統(tǒng)的一種自省機制,知道了是那種類型,我們就可以針對性的獲取幫助,這篇文章主要介紹了linux?type命令用法實戰(zhàn)教程,需要的朋友可以參考下
    2023-05-05
  • shell wait等待命令的具體使用

    shell wait等待命令的具體使用

    本文主要介紹了shell wait等待命令的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Shell腳本判斷進程是否存在的實現(xiàn)示例

    Shell腳本判斷進程是否存在的實現(xiàn)示例

    本文主要介紹了Shell腳本判斷進程是否存在的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 淺談Shell腳本參數(shù)與交互及常見問題

    淺談Shell腳本參數(shù)與交互及常見問題

    本文主要介紹了Shell腳本參數(shù)與交互,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Linux命令行和shell腳本編程寶典 Richard Blum

    Linux命令行和shell腳本編程寶典 Richard Blum

    Linux命令行和shell腳本編程寶典,主要介紹了linux一些命令的使用
    2012-09-09
  • shell腳本函數(shù):控制顏色、定位、居中顯示的代碼

    shell腳本函數(shù):控制顏色、定位、居中顯示的代碼

    這篇文章主要介紹了shell腳本函數(shù):控制顏色、定位、居中顯示的代碼,需要的朋友可以參考下
    2014-04-04
  • Shell腳本傳遞參數(shù)的4種方式實例說明

    Shell腳本傳遞參數(shù)的4種方式實例說明

    Shell腳本是一種命令語言,可以用于自動化執(zhí)行各種任務(wù),在腳本中,我們可以通過參數(shù)來傳遞信息,本文將介紹如何在shell腳本中傳遞參數(shù),包括位置參數(shù)、特殊變量、環(huán)境變量和命名參數(shù),需要的朋友可以參考下
    2023-06-06
  • 面試必問Linux?命令su和sudo的區(qū)別解析

    面試必問Linux?命令su和sudo的區(qū)別解析

    之前一直對?su?和?sudo?這兩個命令犯迷糊,最近專門搜了這方面的資料,總算是把兩者的關(guān)系以及用法搞清楚了,這篇文章來系統(tǒng)總結(jié)一下,對Linux?命令su和sudo相關(guān)知識感興趣的朋友一起看看吧
    2022-07-07
  • linux模糊查找一個文件的方法

    linux模糊查找一個文件的方法

    這篇文章主要介紹了linux模糊查找一個文件的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06

最新評論