一、進程優先級
Linux進程調度及多任務
每個cpu(或者cpu核心)在一個時間點上只能處理一個進程,通過時間片技術,Linux實際能夠運行的進程(和線程數)可以超出實際可用的cpu及核心數量。Linux內核進程調度程序將多個進程在CPU核心上快速切換,從而給用戶多個進程在同時運行的印象;
相對優先級nice
由於不是每個進程都與其他進程同樣重要,可告知進程調度程序為不同的進程使用不同的調度策略,常規系統上運行的大多數進程所使用的調度策略為 SCHED_OTHER(也稱為SCHED_NORMAL),但還有其他一些調度策略用於不同的目的。
SCHED_OTHER 調度策略運行的進程的相對優先級成為進程的 nice 值,可以有40中不同級別的 nice 值;
nice 值越高:表示優先級越低,例如+19,該進程容易將CPU使用量讓給其他進程;
nice 值越低:表示優先級越高,例如-20,該進程更不傾向於讓出CPU;
查看進程的nice級別
1.使用top查看nice級別
NI:實際nice級別
PR:將nice級別顯示為映射到更大優先級隊列,-20映射到0,+19映射到39
2.使用ps查看nice級別
[root@centos6-1 ~]# ps axo pid,command,nice --sort=-nice PID COMMAND NI 1 /sbin/init 0
89 /sbin/mingetty console 0
375 rpcbind 0
424 dbus-daemon --system 0
814 login -- root 0
816 /sbin/mingetty /dev/tty2 0
9106 /usr/bin/python /usr/bin/ss 0
19827 sshd: root@pts/3 0
[root@centos6-1 ~]# ps axo pid,command,nice,cls --sort=-nice PID COMMAND NI CLS 1 /sbin/init 0 TS 89 /sbin/mingetty console 0 TS 375 rpcbind 0 TS 424 dbus-daemon --system 0 TS 814 login -- root 0 TS 816 /sbin/mingetty /dev/tty2 0 TS 9106 /usr/bin/python /usr/bin/ss 0 TS 19827 sshd: root@pts/3 0 TS 19829 -bash 0 TS 21228 /sbin/dhclient -H lcq-cento 0 TS 29860 sshd: root@pts/5 0 TS 29869 sshd: root@notty 0 TS
TS 表示該進程使用的調度策略為 SCHED_OTHER
啟動具有不同nice級別的進程
啟動進程時,通常會繼承父進程的 nice級別,默認為0.
[root@centos6-1 ~]# nice -n 5 sleep 3000 & [1] 30221 [root@centos6-1 ~]# ps axo command,pid,nice |grep sleep
sleep 3000 30221 5
grep sleep 30249 0 [root@centos6-1 ~]#
[root@centos6-1 ~]# nice -n -20 service httpd start [root@centos6-1 ~]# ps axo pid,command,nice,cls | grep httpd 11116 /usr/sbin/httpd -20 TS 11119 /usr/sbin/httpd -20 TS 11120 /usr/sbin/httpd -20 TS 11121 /usr/sbin/httpd -20 TS 11122 /usr/sbin/httpd -20 TS 11123 /usr/sbin/httpd -20 TS 11124 /usr/sbin/httpd -20 TS 11125 /usr/sbin/httpd -20 TS 11126 /usr/sbin/httpd -20 TS
更改現有級別進程的nice級別
1.使用top更改nice 級別
r 調整進程的優先級別(Nice Level)(-20最高) - - - - - - - 0 - - - - - - -(19最低)
2.使用shell更改nice級別
二、作業控制 jobs
作業控制是一個命令行功能,允許一個shell 實例運行和管理多個命令。
如果沒有作業控制,父進程fork() 一個字進程后,將sleeping ,直到子進程退出。
使用作業控制,可以選擇性暫停,恢復,以及異步運行命令,讓 shell 可以在子進程運行期間返回接受其他命令。
foreground,background,and contrlling terminal
foreground: 前台進程是在終端中運行的命令,該終端為進程的控制終端,前台進程接收鍵盤生產的輸入和信號,並允許從終端讀取或寫入到終端。
background: 后台進程沒有控制終端,它不需要終端的交互。
示例1:
[root@linux ~]# sleep 3000 & //運行程序(時),讓其在后台執行
[root@linux ~]# sleep 4000 //^Z,將前台的程序掛起(暫停)到后台
[2]+ Stopped sleep 4000
[root@linux ~]# ps aux |grep sleep root 8895 0.0 0.0 100900 556 pts/0 S 12:13 0:00 sleep 3000 root 8896 0.0 0.0 100900 556 pts/0 T 12:13 0:00 sleep 4000
[root@linux ~]# jobs //查看后台作業
[1]- Running sleep 3000 & [2]+ Stopped sleep 4000
[root@linux ~]# bg %2 //讓作業2在后台運行
[root@linux ~]# fg %1 //將作業1調回到前台
[root@linux ~]# kill %1 //kill 1,終止PID為1的進程
預覽:
[root@linux ~]# (while :; do date; sleep 2; done) & //進程在后台運行,但輸出依然在當前終端
[root@linux ~]# (while :; do date; sleep 2; done) &>/dev/null &
& 放在命令的最后才是后台符
示例2:如何管理遠程主機
[root@linux ~]# ssh 10.18.40.100 [root@www ~]# yum -y install screen //第一次
[root@www ~]# screen -S install_apache
斷網后,重新連接
[root@www ~]# screen -list There are screens on: 28958.install_nginx (Detached) 29013.install_apache (Detached) 2 Sockets in /var/run/screen/S-root. [root@www ~]# screen -r 29013