15.Linux進程管理
2.監控進程狀態
3.管理進程狀態
4.管理后臺進程
5.進程的優先級[進階]
6.系統平均負載[進階]
1.什么是進程
比如: 開發寫的代碼我們稱為程序,那么將開發的代碼運行起來。我們稱為進程。
總結一句話就是: 當我們運行一個程序,那么我們將運行的程序叫進程。
PS1: 當程序運行為進程后,系統會為該進程分配內存,以及進程運行的身份和權限。
PS2: 在進程運行的過程中,系統會有各種指標來表示當前運行的狀態。
2.程序和進程的區別
1.程序是數據和指令的集合,是一個靜態的概念。比如/bin/ls、/bin/cp等二進制文件。同時程序可以長期存在系統中。
2.進程是程序運行的過程,是一個動態的概念。進程是存在生命周期的概念的,也就是說進程會隨著程序的終止而銷毀,不會永久存在系統中。
3.進程的生命周期
生命周期就是指一個對象的生老病死。用處很廣。
當父進程接收到任務調度時,會通過fock派生子進程來處理,那么子進程會繼承父進程屬性。
1.子進程在處理任務代碼時,父進程會進入等待狀態中...
2.子進程在處理任務代碼后,會執行退出,然后喚醒父進程來回收子進程的資源。
3.如果子進程在處理任務過程中,父進程退出了,子進程沒有退出,那么這些子進程就沒有父進程來管理了,就變成僵尸進程。
PS: 每個進程都父進程的PPID,子進程則叫PID。
例: 假設現在我是蔣先生(system進程)....故事持續中.....
2.監控進程狀態
程序在運行后,我們需要了解進程的運行狀態。查看進程的狀態分為: 靜態和動態兩種方式
1.使用ps命令查看當前的進程狀態(靜態)
1)示例、ps -aux常用組合,查看進程 用戶、PID、占用cpu百分比、占用內存百分比、狀態、執行的命令等
狀態描述
USER啟動進程的用戶
PID進程運行的ID號
%CPU進程占用CPU百分比
%MEM進程占用內存百分比
VSZ進程占用虛擬內存大小 (單位KB)
RSS進程占用物理內存實際大小 (單位KB)
TTY進程是由哪個終端運行啟動的tty1、pts/0等 ?表示內核程序與終端無關
STAT進程運行過程中的狀態 man ps (/STATE)
START進程的啟動時間
TIME進程占用 CPU 的總時間(為0表示還沒超過秒)
COMMAND程序的運行指令,[ 方括號 ] 屬于內核態的進程。 沒有 [ ] 的是用戶態進程。
2.STAT狀態的S、Ss、S+、R、R、S+等等,都是什么意思?
STAT基本狀態描述STAT狀態+符號描述
R進程運行s進程是控制進程, Ss進程的領導者,父進程
S可中斷睡眠<進程運行在高優先級上,S<優先級較高的進程
T進程被暫停N進程運行在低優先級上,SN優先級較低的進程
D不可中斷睡眠+當前進程運行在前臺,R+該表示進程在前臺運行
Z僵尸進程l進程是多線程的,Sl表示進程是以線程方式運行
案例一、PS命令查看進程狀態切換
1.在終端1上運行vim
[root@xuliangwei ~]# vim oldboy
2.在終端2上運行ps命令查看狀態
[root@xuliangwei ~]# ps aux|grep oldboy #S表示睡眠模式,+表示前臺運行
root 58118 0.4 0.2 151788 5320 pts/1 S+ 22:11 0:00 oldboy
root 58120 0.0 0.0 112720 996 pts/0 R+ 22:12 0:00 grep --color=auto oldboy
在終端1上掛起vim命令,按下:ctrl+z
3.回到終端2再次運行ps命令查看狀態
[root@xuliangwei ~]# ps aux|grep oldboy #T表示停止狀態
root 58118 0.1 0.2 151788 5320 pts/1 T 22:11 0:00 vim oldboy
root 58125 0.0 0.0 112720 996 pts/0 R+ 22:12 0:00 grep --color=auto oldboy
案例二、PS命令查看不可中斷狀態進程
1.使用tar打包文件時,可以通過終端不斷查看狀態,由S+,R+變為D+
[root@xuliangwei ~]# tar -czf etc.tar.gz /etc/ /usr/ /var/
[root@xuliangwei ~]# ps aux|grep tar|grep -v grep
root 58467 5.5 0.2 127924 5456 pts/1 R+ 22:22 0:04 tar -czf etc.tar.gz /etc/
[root@xuliangwei ~]# ps aux|grep tar|grep -v greproot 58467 5.5 0.2 127088 4708 pts/1 S+ 22:22 0:03 tar -czf etc.tar.gz /etc/
[root@xuliangwei ~]# ps aux|grep tar|grep -v grep
root 58467 5.6 0.2 127232 4708 pts/1 D+ 22:22 0:03 tar -czf etc.tar.gz /etc/
2.使用top命令查看當前的進程狀態(動態)
任務含義
Tasks: 129 total當然進程的總數
1 running正在運行的進程數
128 sleeping睡眠的進程數
0 stopped停止的進程數
0 zombie僵尸進程數
%Cpu(s): 0.7 us系統用戶進程使用CPU百分比
0.7 sy內核中的進程占用CPU百分比,通常內核是于硬件進行交互
98.7 id空閑CPU的百分比
0.0 waCPU等待IO完成的時間
0.0 hi硬中斷,占的CPU百分比
0.0 si軟中斷,占的CPU百分比
0.0 st比如虛擬機占用物理CPU的時間
top 常見指令
字母含義
h查看幫出
1數字1,顯示所有CPU核心的負載
z以高亮顯示數據
b高亮顯示處于R狀態的進程
M按內存使用百分比排序輸出
P按CPU使用百分比排序輸出
q退出top
3.管理進程狀態
當程序運行為進程后,如果希望停止進程,怎么辦呢? 那么此時我們可以使用linux的kill命令對進程發送關閉信號。當然除了kill、還有killall,pkill
1.使用kill -l列出當前系統所支持的信號
雖然linux支持信號很多,但是我們僅列出我們最為常用的3個信號
數字編號信號含義信號翻譯
1SIGHUP通常用來重新加載配置文件
9SIGKILL強制殺死進程
15SIGTERM終止進程,默認kill使用該信號
1.我們使用kill命令殺死指定PID的進程。
1.給 vsftpd 進程發送信號 1,15
[root@xuliangwei ~]# yum -y install vsftpd
[root@xuliangwei ~]# systemctl start vsftpd
[root@xuliangwei ~]# ps aux|grep vsftpd
2.發送重載信號,例如 vsftpd 的配置文件發生改變,希望重新加載
[root@xuliangwei ~]# kill -1 9160
3.發送停止信號,當然vsftpd 服務有停止的腳本 systemctl stop vsftpd
[root@xuliangwei ~]# kill 9160
4.發送強制停止信號,當無法停止服務時,可強制終止信號
[root@xuliangwei ~]# kill -9 9160
2.Linux系統中的killall、pkill命令用于殺死指定名字的進程。我們可以使用kill命令殺死指定進程PID的進程,如果要找到我們需要殺死的進程,我們還需要在之前使用ps等命令再配合grep來查找進程,而killall、pkill把這兩個過程合二為一,是一個很好用的命令。
例1、通過服務名稱殺掉進程
[root@xuliangwei ~]# pkill nginx
[root@xuliangwei ~]# killall nginx
例2、使用pkill踢出從遠程登錄到本機的用戶,終止pts/0上所有進程, 并且bash也結束(用戶被強制退出)
[root@xuliangwei ~]# pkill -9 -t pts/0