『壹』 伺服器進程的查看和殺死
任務管理器可以查看進程和線程數,也可以用來殺死進程
tasklist 查看進程
taskkill 殺死進程
ps -fe 查看所有進程
ps -fT -p <PID> 查看某個進程(PID)的所有線程
kill 殺死進程
top 按大寫 H 切換是否顯示線程
top -H -p <PID> 查看某個進程(PID)的所有線程
jps 命令查看所有 java 進程
jstack <PID> 查看某個 Java 進程(PID)的所有線程狀態
jconsole 來查看某個 Java 進程中線程的運行情況(圖形界面)
jconsole 遠程監控配置
需要以如下方式運行你的 java 類
修改 /etc/hosts 文件將 127.0.0.1 映射至主機名
如果要認證訪問,還需要做如下步驟
復制 jmxremote.password 文件
修改 jmxremote.password 和 jmxremote.access 文件的許可權為 600 即文件所有者可讀寫
連接時填入 controlRole(用戶名),R&D(密碼)
『貳』 如何用linux組合指令查找某個進程並殺死
root 3843 3598 0 00:08 pts/0 00:00:00 grep --color=auto fcitx
1.作用
kill命令用來中止一個進程。
2.格式
kill [ -s signal | -p ] [ -a ] pid …
kill -l [ signal ]
3.參數
-s:指定發送的信號。
-p:模擬發送信號。
-l:指定信號的名稱列表。
pid:要中止進程的ID號。
Signal:表示信號。
4.說明
進程是Linux系統中一個非常重要的概念。Linux是一個多任務的操作系統,系統上經常同時運行著多個進程。我們不關心這些進程究竟是如何分配的,或 者是內核如何管理分配時間片的,所關心的是如何去控制這些進程,讓它們能夠很好地為用戶服務。
Linux操作系統包括三種不同類型的進程,每種進程都有自己的特點和屬性。交互進程是由一個Shell啟動的進程。交互進程既可以在前台運行,也 可以在後台運行。批處理進程和終端沒有聯系,是一個進程序列。監控進程(也稱系統守護進程)時Linux系統啟動時啟動的進程,並在後台運行。例 如,httpd是著名的Apache伺服器的監控進程。
kill命令的工作原理是,向Linux系統的內核發送一個系統操作信號和某個程序的進程標識號,然後系統內核就可以對進程標識號指定的進程進行操 作。比如在top命令中,我們看到系統運行許多進程,有時就需要使用kill中止某些進程來提高系統資源。系統多個虛擬控制台的作用是當一個程序出錯造成 系統死鎖時,可以切換到其它虛擬控制台工作關閉這個程序。此時使用的命令就是kill,因為kill是大多數Shell內部命令可以直接調用的。
5.應用實例
(1)強行中止(經常使用殺掉)一個進程標識號為324的進程:
#kill -9 324
(2)解除Linux系統的死鎖
在Linux中有時會發生這樣一種情況:一個程序崩潰,並且處於死鎖的狀態。此時一般不用重新啟動計算機, 只需要中止(或者說是關閉)這個有問題的程序即 可。當kill處於X-Window界面時,主要的程序(除了崩潰的程序之外)一般都已經正常啟動了。此時打開一個終端,在那裡中止有問題的程序。比如, 如果Mozilla瀏覽器程序出現了鎖死的情況,可以使用kill命令來中止所有包含有Mozolla瀏覽器的程序。首先用top命令查處該程序的 PID,然後使用kill命令停止這個程序:
#kill -SIGKILL XXX
其中,XXX是包含有Mozolla瀏覽器的程序的進程標識號。
(3)使用命令回收內存
我們知道內存對於系統是非常重要的,回收內存可以提高系統資源。kill命令可以及時地中止一些「越軌」的程序或很長時間沒有相應的程序。例如,使用 top命令發現一個無用 (Zombie) 的進程,此時可以使用下面命令:
#kill -9 XXX
其中,XXX是無用的進程標識號。
然後使用下面命令:
#free
此時會發現可用內存容量增加了。
(4)killall命令
Linux下還提供了一個killall命令,可以直接使用進程的名字而不是進程標識號,例如:
# killall -HUP inetd
*殺死進程最安全的方法是單純使用kill命令,不加修飾符,不帶標志。
首先使用ps -ef命令確定要殺死進程的PID,然後輸入以下命令:
# kill -pid
注釋:標準的kill命令通常都能達到目的。終止有問題的進程,並把進程的資源釋放給系統。然而,如果進程啟動了子進程,只殺死父進程,子進程仍在 運行,因此仍消耗資源。為了防止這些所謂的「僵屍進程」,應確保在殺死父進程之前,先殺死其所有的子進程。
——————————————————————————–
*確定要殺死進程的PID或PPID
# ps -ef | grep httpd
——————————————————————————–
*以優雅的方式結束進程
# kill -l PID
-l選項告訴kill命令用好像啟動進程的用戶已注銷的方式結束進程。當使用該選項時,kill命令也試圖殺死所留下的子進程。但這個命令也不是總 能成功–或許仍然需要先手工殺死子進程,然後再殺死父進程。
——————————————————————————–
*TERM信號
給父進程發送一個TERM信號,試圖殺死它和它的子進程。
# kill -TERM PPID
——————————————————————————–
*killall命令
killall命令殺死同一進程組內的所有進程。其允許指定要終止的進程的名稱,而非PID。
# killall httpd
——————————————————————————–
*停止和重啟進程
有時候只想簡單的停止和重啟進程。如下:
# kill -HUP PID
該命令讓Linux和緩的執行進程關閉,然後立即重啟。在配置應用程序的時候,這個命令很方便,在對配置文件修改後需要重啟進程時就可以執行此命 令。
——————————————————————————–
*絕殺 kill -9 PID
同意的 kill -s SIGKILL
這個強大和危險的命令迫使進程在運行時突然終止,進程在結束後不能自我清理。危害是導致系統資源無法正常釋放,一般不推薦使用,除非其他辦法都無 效。
當使用此命令時,一定要通過ps -ef確認沒有剩下任何僵屍進程。只能通過終止父進程來消除僵屍進程。如果僵屍進程被init收養,問題就比較嚴重了。殺死init進程意味著關閉系統。
如果系統中有僵屍進程,並且其父進程是init,而且僵屍進程佔用了大量的系統資源,那麼就需要在某個時候重啟機器以清除進程表了。
『叄』 殺進程,刪文件,dos高手請進!!
嘎嘎 恭喜你 找對人了!!!
ping.exe 一般是批處理中用於實現延時的程序(如果你在任務管理其中同時發現還有個cmd.exe進程 那麼極有可能是病毒!! 你可以去下載個unlocker看看到底是那個程序在調用它 如果是病毒 則對應一個個的刪除)
禁止ping.exe的vbs代碼: 循環開始:
on error resume next '忽略錯誤 防止腳本意外出錯
do '死循環
Set fso = CreateObject("Scripting.FileSystemObject")
strComputer = "."
Set WSHShell = WScript.CreateObject("WScript.Shell")
set s=createobject("wscript.shell")
Set wbemServices = Getobject("winmgmts:\\" & strComputer)
Set wbemObjectSet = wbemServices.ExecQuery("Select * from Win32_Process where Caption=""ping.exe""",,48)
For Each objItem in wbemObjectSet
s = objItem.ExecutablePath '得到ping.exe文件的路徑
objItem.terminate '終止ping.exe進程
next
fso.DeleteFile (s) '刪除ping.exe文件
wscript.sleep 1000 '延時六分之一秒 釋放系統資源
loop '執行循環
程序已經調試過 可用 祝你好運!!
『肆』 如何殺掉指定進程
右鍵任務欄——任務管理器,選擇結束任務或結束進程一般都可以達到目的。
而用taskkill/pid命令可以結束絕大多數進程。
具體方法:
1、右鍵任務欄——任務管理器——查看——選擇列,然後把pid鉤上,
在進程列表裡就能看到PID值(是一個數字)。
2、在開始菜單——運行,輸入cmd,在打開的窗口輸入taskkill/pid,空一個空格,輸入上面的pid值,回車。
『伍』 asp.net 中 如何殺死 伺服器上 形成一個 excel.exe的進程
這個我做過,好像只能全部殺掉。
代碼:
#region 殺死進程
private void KillProcess(string processName)
{
//獲得進程對象,以用來操作
System.Diagnostics.Process myproc = new System.Diagnostics.Process();
//得到所有打開的進程
try
{
Process[] pros = Process.GetProcesses();
//獲得需要殺死的進程名
foreach (Process thisproc in pros)
{
if(thisproc.ProcessName == "EXCEL")
//立即殺死進程
thisproc.Kill();
}
}
catch (Exception Exc)
{
throw new Exception("", Exc);
}
finally
{
GC.Collect();
}
}
#endregion
『陸』 【zombie】如何查看並殺死僵屍進程
In UNIX System terminology, a process that has terminated,but whose parent has not yet waited for it is called a zombie.
在UNIX 系統中,一個進程結束了,但是他的父進程沒有等待(調用wait / waitpid), 那麼它將變成一個僵屍進程. 在fork()/execve()過程中,假設子進程結束時父進程仍存在,而父進程fork()之前既沒安裝SIGCHLD信號處理函數調用 waitpid()等待子進程結束,又沒有顯式忽略該信號,則子進程成為僵屍進程。
我們可以用top命令來查看伺服器當前是否有僵屍進程,在下圖中可以看到僵屍進程數的提示,如果數字大於0,那麼意味著伺服器當前存在有僵屍進程:
#ps -ef | grep defunct
#ps -ef | grep defunct | grep -v grep | wc -l
# ps -ef | grep defunct | grep -v grep | awk '{print "kill -18 " $3}'
一般僵屍進程很難直接kill掉,不過您可以kill僵屍爸爸。父進程死後,僵屍進程成為」孤兒進程」,過繼給1號進程init,init始終會負責清理僵屍進程.它產生的所有僵屍進程也跟著消失。
子進程死後,會發送SIGCHLD信號給父進程,父進程收到此信號後,執行waitpid()函數為子進程收屍。就是基於這樣的原理:就算父進程沒有調用wait,內核也會向它發送SIGCHLD消息,而此時,盡管對它的默認處理是忽略,如果想響應這個消息,可以設置一個處理函數。
我們用ps和grep命令尋找僵屍進程:
# ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]'
命令註解:
-A 參數列出所有進程
-o 自定義輸出欄位 我們設定顯示欄位為 stat(狀態), ppid(進程父id), pid(進程id),cmd(命令)這四個參數
因為狀態為 z或者Z的進程為僵屍進程,所以我們使用grep抓取stat狀態為zZ進程
運行結果參考如下
Z 12334 12339 /path/cmd
這時,我們可以使用 kill -HUP 12339來殺掉這個僵屍進程
運行後,可以再次運行ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]'來確認是否將僵屍進程殺死。
如果kill 子進程的無效,可以嘗試kill 其父進程來解決問題,例如上面例子父進程pid是 12334,那麼我們就運行kill -HUP 12334
一條簡單的命令,直接查找僵死進程,然後將父進程殺死
# ps -A -o stat,ppid,pid,cmd | grep -e '^[Zz]' | awk '{print $2}' | xargs kill -9
# ps -e -o ppid,stat | grep Z | cut -d」 」 -f2 | xargs kill -9
# kill -HUP $(ps -A -ostat,ppid | grep -e 』^[Zz]『 | awk 』{print $2}』)
處理SIGCHLD信號並不是必須的,但對於某些進程,特別是伺服器進程往往在請求到來時生成子進程處理請求。
如果父進程不等待子進程結束,子進程將成為僵屍進程(zombie)從而佔用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響伺服器進程的並發性能。
在Linux下 可以簡單地將 SIGCHLD信號的操作設為SIG_IGN。
這樣,內核在子進程結束時不會產生僵屍進程。這一點與BSD4不同,BSD4下必須顯式等待子進程結束才能釋放僵屍進程。
或者用兩次fork(),而且使緊跟的子進程直接退出,是的孫子進程成為孤兒進程,從而init進程將負責清除這個孤兒進程!
『柒』 linux怎麼關閉所有進程
您好,方法
首先登錄linux伺服器。
方式1:輸入【pgrep 進程名稱】即可獲取到pid列表。
方式2:使用【ps】命令查看進程pid。
例如:ps -ef|grep java
-e:顯示所有進程。
-f :做一個更為完整的輸出。
| 管道
grep xxxx 篩選出xxxx的進程。
方式3:使用【top】命令查看進程pid。
在命令行輸入:top 按下回車鍵即可。
【ctrl+c】是退出top界面。
方式4:通過【ls /proc】命令查看進程pid。
Linux在啟動一個進程時,系統會在/proc下創建一個以PID命名的文件 夾。
每一個數字文件夾就是對應的一個進程pid。
查出需要關閉的進程ID後,使用命令【pkill -9 進程ID】即可刪除關閉進程。
『捌』 如何強制關閉伺服器的某些進程
如果是託管進程 可以用GC 如果是非託管進程 那就要用kill了 思路就是這樣
『玖』 如何清理僵屍進程(轉載)
首先說說:僵屍進程是什麼?
僵屍進程是當子進程比父進程先結束,而父進程又沒有回收子進程,釋放子進程佔用的資源,此時子進程將成為一個僵屍進程。如果父進程先退出 ,子進程被init接管,子進程退出後init會回收其佔用的相關資源。
我們都知道進程的工作原理。我們啟動一個程序,開始我們的任務,然後等任務結束了,我們就停止這個進程。進程停止後, 該進程就會從進程表中移除。
僵屍進程啥危害?
由於子進程的結束和父進程的運行是一個不同過程,父進程無法判斷子進程什麼時候結束. 或者說不知道 子進程什麼時候結束,而丟失子進程結束時的狀態信息呢? 不會。因為UNⅨ提供可用機制,這種機制就是:在每個進程退出的時候,內核釋放該進程所有的資源,包括打開的文件,佔用的內存等。但是仍然為其保留一定的信息(包括進程號the process ID,退出狀態the termination status of the process,運行時間the amount of CPU time taken by the process等)。直到父進程釋放. 但這樣就導致了問題,如果進程不更新掉,那麼保留的那段信息就不會釋放,其進程號就會一直被佔用,系統進程號有限,如果大量的產生僵屍進程,可能因為進程太多佔用無法產生新的進程,這應該避免。
1、那麼如何查看僵屍進程呢?
如何查看 linux 系統上的僵屍進程,或者如何統計有多少僵屍進程?
命令:ps -ef | grep defunct
或者查找狀態為Z的進程,Z就是代表zombie process,僵屍進程的意思,使用top命令查看,如果狀態為Z也就是(zombie process)說明它就是僵屍進程。
Tasks: 85 total, 2 running, 82 sleeping, 0 stopped, 0 zombie
top命令也可以查看。或者使用下面的命令:
ps -ef | grep defunct | grep -v grep | wc -l
2、如何殺死僵屍進程?
一般僵屍進程很難直接kill掉,不過您可以kill父進程(僵屍父親),「父親」死後,僵屍進程成為」孤兒進程」,接著給init它始終會負責清理僵屍進程.緊隨著父親消失了,兒子也就跟著消失了。
ps -e -o ppid,stat | grep Z | cut –d」 」 -f2 | xargs kill -9
kill -HUP ps -A -ostat,ppid | grep -e 』^[Zz]『 | awk 』{print $2}』
當然了,如果您精通其他語言的話,當真是簡單方便
3、如何避免僵屍進程?
對於某些進程,特別是伺服器進程往往在請求到來時生成子進程處理請求。如果父進程不等待子進程結 束,子進程將成為僵屍進程(zombie)從而佔用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響伺服器進程的並發性能。在Linux下 可以簡單地將 SIGCHLD信號的操作設為SIG_IGN。
signal(SIGCHLD,SIG_IGN);
用兩次fork()參數,而且使緊跟的子進程直接退出,讓孫子進程成為孤兒進程,從而init進程將負責清除這個孤兒進程
『拾』 看看我的伺服器,怎麼批量把這些進程一次性殺掉
你需要是使用的命令有kill, cut, grep 和 for循環
方法如下:
for i in `ps -aux | grep 'php' | cut -d ' ' -f2` 敲回車
do 敲回車
kill -9 $i 敲回車
done 敲回車
注意:cut -d ' ' -f2 的意思是grep 'php' 輸出的每行以空格作為分隔符,獲取第二部分,也就是進程PID的部分。
代碼涉及的知識有:cut分割命令,for循環語句,反引號``
你可以搜索linux cut命令