Linux系統下有一個直接終止進程的命令,這個命令的代碼也是非常霸氣,直接就是英文的kill。既然這個命令這么有“殺氣”,為了防止“誤傷”,下面小編就給大家來普及一下Linux使用kill命令的注意事項。
使用kill命令注意事項
1、在檢查一個角本Bug的時候,你會發現killall命令與kill命令的一個不同之處: 假設有腳本 test.pl ,假設內容如下: #!/usr/bin/perl -w sleep 60;
則測試結果如下: 1、如果通過 /home/MNET/m_yancyliu/tmp/x.pl 命令啟動,此時ps下命令行顯示如下: /usr/bin/perl -w /home/MNET/m_yancyliu/tmp/x.pl
結果如下: killall x.pl 命令可以殺掉該腳本, killall perl 命令則無法殺掉該進程
2、 如果通過 /usr/bin/perl -w /home/MNET/myancyliu/tmp/x.pl 命令啟動,此時ps下命令行顯示: /usr/bin/perl -w /home/MNET/m_yancyliu/tmp/x.pl
結果如下: killall perl 命令可以殺掉該進程
killall x.pl 命令則無法殺掉該進程 此時,如果通過 ps uxfww 命令查看對應的進程樹,會發現上面兩種啟動方式的進程樹是一樣的: (如果要查看所有進程的進程樹,可以使用命令 ps axfww) -eash | _ /bin/bash | _ /usr/bin/perl -w /home/MNET/m_yancyliu/tmp/test.pl
上面的結果顯示,盡管通過 ps -ef 命令看到的命令行顯示是相同的,但操作系統仍然會記錄該進程的啟動信息。
1、直接通過腳本名調用時,OS認為進程對應的程序名就是腳本名,因為進程是通過腳本名啟動的。 2、如果通過 perl 或 shell 加載腳本名的方式調用時,操作系統會認為進程的程序名稱是 perl/shell,而腳本名則是做為進程的參數傳入,因為此時進程是通過perl/shell啟動的。
至于操作系統是如何區分出這兩種方式的呢,這里對比兩種啟動方式下的 /proc/$pid 目錄: 1、直接通過腳本名調用時,/proc/$pid 目錄下內容如下: cmdline文件中內容為: usr/bin/perl -w /home/MNET/m_yancyliu/tmp/test.pl stat文件內容為:
12242 (test.pl) S 3102 12242 3102 9472041 12242 8396800 456 0 3 0 0 0 0 0 18 0 1 0 357357658 4358144 361 4294967295 134512640 135656772 3215679088 3215678100 3084573003 0 0 128 0 3741425540 0 0 17 3 0 0
2、通過 perl 加載腳本名時,/proc/$pid 目錄下內容如下:
cmdline文件中內容為: usr/bin/perl -w /home/MNET/m_yancyliu/tmp/test.pl
stat文件內容為:
13372 (perl) S 3102 13372 3102 9472041 13372 8396800 460 0 0 0 0 0 0 0 18 0 1 0 357376374 4358144 362 4294967295 134512640 135656772 3218100000 3218099012 3084704075 0 0 128 0 3577044868 0 0 17 2 0 0
顯然,我們使用 ps 命令看到的進程統計信息,是與 /proc/$pid/cmdline中看到的。一致。 而在進程的cpu統計信息 /proc/$pid/stat 中看到的內容則是不同的,這里標識了操作系統認可的程序名稱,即進程是如何啟動的。上面第一個數字均為進程ID。
于是,根據進程的CPU活動統計信息,killall命令能夠區分兩種不同的方式啟動的進程,從而做出不同的處理。 對于這兩種啟動方式引起的不同,在使用 killall 命令時要注意,在使用命令行啟動進程時也要注意。
以上就是Linux使用kill命令的注意事項了,kill命令已經很有力度了,居然還有個killall(殺死全部),這也真夠了。
評論
查看更多