1. 程式人生 > >開發除錯linux服務時幾個好用的程序和埠查詢命令組合和簡單指令碼(ps netstat awk grep)

開發除錯linux服務時幾個好用的程序和埠查詢命令組合和簡單指令碼(ps netstat awk grep)

這幾天在搭建flume服務並在其框架下開發,反覆除錯輸入命令讓人不厭其煩,因此在這裡記錄一下自己找到的一些小技巧:

首先,把自己的應用程式做成一個service是一個很好的選擇,一個service就需要支援start 和 stop,start能啟動程式,stop能找到start所啟動的程式的程序並且關掉它。

可以直接根據/etc/init.d/下的服務指令碼來改,但我遇到了問題:因為那些系統服務指令碼都是基於start-stop-daemon命令,這個命令很強大,可以啟動一個可執行檔案並且把程序PID,寫入指定的檔案裡,這樣在停止程序時可以直接讀取檔案來關掉程序。

但我用這個命令來啟動自己的程式時,程式啟動成功,但是PID檔案在無任何錯誤資訊的情況下就是沒法生成,測試了root許可權執行,也測試了各種寫入路徑(不需要高許可權的),統統不行,於是決定慢慢研究這個問題的同時,先用簡單的方法去解決我的需求。

啟動程式很簡單,作為服務,需要後臺執行,假設你的可執行檔名叫做PROGRAM。

所以啟動就需要  :

nohup PROGRAM [args] &

要關閉就需要    :

#PROGRAM是程序名

PID = `pidof PROGRAM`

if [ ! -z "$PID" ]; then
     kill -15 $PID
     fi


但是對於java或者python 程式,程序是java或者python,沒有可區分度,所以不能用"pidof"命令,那麼只能用"ps -ef"命令,用grep對程序資訊進行過濾,來找到合適的程序

而一臺機器上可以有多個flume服務,每個服務可能就執行引數有一些區別,所以要用多個grep:

  PID=`ps -ef | grep java | grep flume | awk '{ print $2 }'`
     if [ ! -z "$PID" ]; then
     kill -15 $PID
     fi

這裡用到了awk命令,取出了"ps"命令列印資訊的第二列PID的值。

這樣一個簡單服務的start和stop就完成了。

我還遇到另一個需求,就是檢查某埠的佔用情況,並且強制關閉佔用這個埠的程序:

# netstat -tlnpa | grep 44444
tcp6       0      0 10.58.242.18:44444      :::*                    LISTEN      25049/java

埠查詢結果有如上格式,那麼我們可以根據這個格式編寫如下指令碼:
pinfo=`netstat -tlnpa | grep 44444`

PID=`awk '{split("'$pinfo'", array, "/");print array[2]}' `

if [ ! -z "$PID" ]; then
     kill -15 $PID
     fi

就搞定了。

深入挖掘awk 和 grep 還可以有很多用處,作為shell文字處理的利器,我這裡只是日常簡單的應用,希望對大家有幫助。