后台運行linux命令,殺死僵屍進程


殺死僵屍進程  https://www.jb51.net/LINUXjishu/457748.html

defunct進程是指出錯損壞的進程,父子進程之間不會再通信。有時,它們會演變成“僵屍進程”,存留在你的系統中,直到系統重啟。可以嘗試 “kill -9” 命令來清除,但多數時候不管用。
為了殺死這些defunct進程,你有兩個選擇:
1.重啟你的計算機
2.殺死父進程

ps -A | grep defunct                       //查看僵屍進程

ps -ef | grep defunct | more                  //查看僵屍進程父進程   UID PID PPID (第三列)

kill -9  PPID

 

 

1. 后台執行

一般運行linux上的程序都是執行 .sh 文件(./sh文件),那如果不影響當前CMD窗口的操作,需要后台運行怎么辦呢?

這時就需要借助 nohup& 命令來實現。

 

(1) nohup 

    加在一個命令的最前面,表示不掛斷的運行命令

(2) &  或者 &!

  加在一個命令的最后面,表示這個命令放在后台執行

1
nohup java -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -jar test.jar $1 $2 $3 &

 

放入后台后,要正常退出終端,后台運行才生效

exit

 

2. 查看后台運行的命令

有兩個命令可以來查看,ps 和 jobs。

 jobs 只能查看當前終端后台執行的任務,換了終端就看不見了

ps命令適用於查看瞬時進程的動態,可以看到別的終端的任務

(1) jobs     jobs -l(帶PID查看后台進程)

1
 
[root@localhost test]# jobs
[1]- 運行中        nohup java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar $1 $2 $3 &(工作目錄:/home/ams/ams-server/test)
[2]+ 運行中        nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3 &

先后起了兩個后台運行的進程,使用jobs后都顯示出來了。“+”代表最近的一個任務(當前任務),“-”代表之前的任務

只有在當前命令行中使用 nohup和& 時,jobs命令才能將它顯示出來。如果將他們寫到 .sh 腳本中,然后執行腳本,是顯示不出來的

 比如執行下面這個腳本后,jobs顯示不出來:

1
2
#!/bin/bash
nohup java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar $1 $2 $3 &

(2) ps命令    ps aux|grep PID   (不分終端查看后台進程)   或者  ps -ef|grep  腳本名

1
2
3
4
[root@localhost test]# ps -aux|grep java
root   21219 0.3 3.9 6258172 148900 pts/0 Sl  10:08  0:02 java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar
root   21662 0.2 3.0 5041008 116648 pts/0 Sl  10:10  0:01 java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar
root   23761 0.0 0.0 112664  972 pts/0  S+  10:19  0:00 grep --color=auto java

這個是查看進程常用的命令,不多說了。

a: 顯示所有程序  u: 以用戶為主的格式來顯示   x: 顯示所有程序,不以終端機來區分

ps -elf  或  ps aux

3. 關閉當前后台運行的程序

kill 命令

(1)通過jobs命令查看jobnum,然后執行   killall %jobnum

(2)通過ps命令查看進程號PID,然后執行  kill %PID

pkill 進程名

如果是前台進程的話,直接執行 Ctrl+c 就可以終止了

4. 前后台進程的切換與控制

(1)fg命令

      將后台中的命令調至前台繼續運行

     如果后台中有多個命令,可以先用jobs查看jobnun,然后用 fg %jobnum 將選中的命令調出

(2)Ctrl + z 命令

將一個正在前台執行的命令放到后台,並且處於暫停狀態

(3)bg命令

將一個在后台暫停的命令,變成在后台繼續執行

如果后台中有多個命令,可以先用jobs查看jobnum,然后用 bg %jobnum 將選中的命令調出繼續執行。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@localhost test]# jobs
[1]- 運行中        nohup java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar $1 $2 $3 &(工作目錄:/home/test)
[2]+ 運行中        nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3 &
  
// 使用fg 后,將任務2調至前台運行
[root@localhost test]# fg 2
nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3
  
^Z
// 使用ctrl+Z后,將任務2放置到后台,並暫停
[2]+ 已停止        nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3
  
// 使用bg 后,激活任務2的運行
[root@localhost test]# bg 2
[2]+ nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3 &


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM