linux 系統進程

進程:是已經啓動的可執行的運行實例

組成

  • 已分配內存的地址空間
  • 安全屬性,包括所有權憑據和特權
  • 程序代碼的一個或多個執行線程

進程狀態

  • 程序:二進制文件
  • 進程:是程序運行時的過程,動態,有生命週期及運行狀態
父進程複製自己的地址空間創建一個新的進程結構,每個新進程分配一個唯一的進程IP(PID),滿足跟蹤安全性,

PID和父進程(PPID)是子進程環境的元素,

任何進程都可以創建子進程,每個進程都是第一個系統進程的後代
  • centos5,6的PID爲1的進程是init
  • centos7的PID爲1的進程爲systemd

殭屍進程

比較容易理解的是:
    父進程退出了,子進程沒有退出. 這些子進程沒有父進程來管理,就變成了殭屍進程

 

  • 啓動進程的用戶ID(UID)和所屬的組(GID)
  • 進程狀態:運行R, 休眠S, 殭屍Z

 

PS查看進程工具

常用的參數

a: 顯示跟當前終端關聯的所有進程
u: 基於用戶的格式顯示
x: 顯示所有進程,不以終端機來區分

user:啓動這些進程的用戶
pid:進程的id
%cpu:進程佔用cpu百分比
%men:進程佔用內存的百分比
vsz:進程佔用的虛擬內存大小(單位kb)
rss進程佔用的物理內存大小(kb)
stat:該進程目前的狀態
  R:該程序目前正在運行,或者可被運行
  S:該程序目前正在睡眠
  T:該程序目前正在偵測或者停止了,
  Z:該程序應該已經終止,但是其父進程無法正常的終止他,造成zombie殭屍程序的狀態
  D:不可中斷狀態
五個基本狀態後面還可以加一些字母
  <:表示進程運行在高優先級上
  N:表示進程運行在低優先級上
  L:表示進程有頁面鎖定在內存中
  s:表示進程是控制進程
  l:表示進程是多線程的
  +:表示當前進程運行在前臺
start:被觸發啓動的時間
time:實際使用cpu運作的時間,有顯示0:00的,耗費cpu資源不到1秒
command:改程序的實際指令

 

還可以通過ps -ef來查看進程

-e: 顯示所有進程
-f: 顯示完整格式輸出

UID:啓動這些進程的用戶
PID:進程的ID
PPID:父進程的ID號
C:進程生命週期的利用率
Stime:啓動啓動時的系統時間
tty:進程在哪個終端上運行
  ?:表示與終端沒有關係,大部分是內核的
  tty1-tty6是本機上面的登入者程序,若爲pts/0等等的,則表示由網絡連接進主機的程序(是虛擬的)
time:運行進程累計需要的cpu時間
cmd:啓動的程序名稱

 

uptime 查看系統負載

20:25:36 :當前時間
up 4 days: 系統運行時間,說明這臺服務器已經開機4天了
3 user: 當前登錄的用戶數
load average: 0.00, 0.01, 0.05:  cpu系統負載,即cpu任務隊列的平均長度,三個數值分別是1分鐘,5分鐘,15分鐘的平均值

互動

互動:
找出當前系統中,cpu負載過高的服務器
服務器:load average 0.15, 0.08, 0.01         1核
服務器:load average 4.15, 6.08, 6.01        1核
服務器:load average 10.15, 10.08, 10.01    4核

答案:4核
經驗:單核心,1分鐘的系統平均負載不差過3,就可以,這是個經驗值

 

top命令

第一行,系統負載
第二行,進程信息
    tesks(當前任務數)
    running 運行
    sleeping 睡眠
    stopped 終止
    zombie 殭屍進程

第三行cpu信息
    us:用戶佔用cpu的時間
    sy:內核佔用cpu
    ni:用戶進程空間內改變過優先級佔用的cpu
    id:空閒cpu的百分比
    wa:當對磁盤進行大量寫時,發現IO等待會佔用很多cpu,如果正常使用佔用比較多cpu,磁盤性能有問題
    hi:硬件中斷佔用的cpu,硬件驅動通常是內核中的一個子進程,而不是一個獨立的進程
    si:軟中斷,佔用的cpu百分比,往磁盤寫入數據有個隊列,所佔用的時間
    st:虛擬機佔用物理機cpu時間

第四行內存信息
  單位kb
  total 總內存
  free 空閒
  used 佔用
  buff/cache 這裏的緩存是可以釋放的

第五行 swap
  total 交換區總量
  free 空閒的交換區總量
  used 使用的交換區總量
  avail Mem 總共的可利用內存是多少
  注意:如果swap分區,被使用,那麼你的內存不夠用了
快捷鍵
默認 3s 刷新一次,按s修改刷新時間
按空格立即刷新

按大寫的 C 按照cpu佔用排序
按大寫的 M 安裝內存佔用排序

按數字鍵1,顯示每個內核的cpu使用頻率
按u: 顯示指定的用戶
h:幫助
top -p 1  通過進程ID查看單個進程

 

找出系統中佔用系統進程最多的進程

top 後按大寫的P

在linux系統中最多可以使用100%CPU嗎

理論上:如果你是4核心的cpu,你可以運行400%

 

 

lsof命令

-p 進程號,列出指定進程號打開的文件
-i  條件:列出符合條件的進程

查看某個進程讀了那些文件,調用了那些東西呢,一般用於木馬進程

lsof -p 進程ID

查看端口,或者看黑客開啓的後門端口是哪個進程在使用

lsof -i:22

 

 

pstree工具

  • 以樹形圖顯示進程,只顯示進程的名字,且相同進程合併顯示
  • pstree -p顯示進程ID

 

前臺進程:
是在終端中運行的命令,那麼終端就是進程的控制終端
一旦這個終端關閉,這個進程也隨之消失

後臺進程,
也叫守護進程,是運行在後臺的一種特殊進程,不受終端控制,不需要終端的交互,
linux的大多數的服務器就是用守護進程來實現的, 比如web服務器httpd等

 

前臺後臺進程切換

&用在一個命令的最後,可以把這個命令放到後臺執行

 

 ctrl + z可以將一個正在前臺執行的程序放到後臺

jobs查看當前有多少在後臺運行的進程,這是一個作業控制命令

 

 fg命令將後臺中的命令調到前臺繼續運行,

如果後臺中有多個命令可以用 fg %jobnumber將選中的命令調出,

%jobnumber是通過jobs命令查到的後臺正在執行的命令的序號(不是pid) 

 

bg命令將一個在後臺中暫停的進程,變成繼續執行,

用法同上

 

 

關閉進程

kill [信號] [進程ID]
kill -l        -->列出指定的信號

 常用的信號

信號編號  信號名                      解釋
1        SIGHUP        重新加載配置
2        SIGINT         鍵盤中斷ctrl+c
3        SIGQUIT        退出
9        SIGKILL        強制退出
15        SIGTERM        終止(正常結束),缺省信號
18        SIGCONT        繼續
19        SIGSTOP        停止
20        SIGTSTP        暫停 ctrl+z

killall 和 pkill 命令通過指定名字來殺死進程

killall sshd
pkill sshd

 

 

 

進程優先級管理

優先級的取值範圍(-20,19),越小優先級越高,默認優先級是0
nice -n

 

nice -n 5 vim a.txt
ctrl+z掛起進程

查看進程的PID
查看PID:ps -axu | grep vim

 

 根據PID查看進程的信息

可以發現NI優先值是5

 

 

 

 

實戰:使用screen後臺實行執行命令備份命令
場景:公司晚上需要備份1t數據,我再xshell上直接執行備份腳本back.sh可以嗎?
或直接運行back.sh&放到後臺運行可以嗎?
當關了xshell,back.sh&還在後臺執行嗎?

xshell長時間連接,如果本地網絡偶爾斷開或者xshell不小心關閉,都會讓後臺運行的備份命令停止運行的
正確做法使用:screen
安裝yum install screen

 

 用法:

執行screen,將打開一個全新的會話
運行你的備份任務,或者vim a.txt命令
這時可以鍵入快捷鍵ctrl+a+d  
就已經分離出一個單獨的會話

screen -ls 查看已經建立的會話id
screen -r 25448 通過PID 重新連接會話
screen -S text  指定會話名稱
當不想使用screen會話了,exit退出

 

 

 

 

 

 

  

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章