在 Linux 中,線程是由進(jìn)程來實現(xiàn)的,可以認(rèn)為線程就是一個輕量級的進(jìn)程,因此,線程調(diào)度是按照進(jìn)程調(diào)度的方式來進(jìn)行的。這樣設(shè)計,線程調(diào)度流程可以直接復(fù)用進(jìn)程調(diào)度流程,沒必要再設(shè)計一個進(jìn)程內(nèi)的線程調(diào)度器了。
目前創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計、霍邱網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
在 Linux 中,進(jìn)程調(diào)度器是基于進(jìn)程的調(diào)度策略與調(diào)度優(yōu)先級來決定調(diào)度哪個進(jìn)程運行。
調(diào)度策略主要包括:
調(diào)度優(yōu)先級的范圍是 0~99,數(shù)值越大,表示優(yōu)先級越高。
其中,SCHED_OTHER、SCHED_IDLE、SCHED_BACH 為非實時調(diào)度策略,其調(diào)度優(yōu)先級為 0。而 SCHED_FIFO、SCHED_RR 是實時調(diào)度策略,其調(diào)度優(yōu)先級范圍為 1~99。
實時調(diào)度策略的進(jìn)程總是比非實時調(diào)度策略的進(jìn)程優(yōu)先級高。
在 Linux 內(nèi)部實現(xiàn)中,調(diào)度器會為每個可能的調(diào)度優(yōu)先級維護(hù)一個可運行的進(jìn)程列表,以最高優(yōu)先級列表頭部的進(jìn)程作為下一次調(diào)度的進(jìn)程,所有的調(diào)度都是搶占式的,如果一個具有更高調(diào)度優(yōu)先級的進(jìn)程轉(zhuǎn)換為可運行狀態(tài),那么當(dāng)前運行的進(jìn)程將被強(qiáng)制進(jìn)入其等待的隊列中。
SCHED_OTHER
該調(diào)度策略是默認(rèn)的 Linux 分時調(diào)度策略,該調(diào)度策略為非實時的,其調(diào)度優(yōu)先級總是為 0。
對于該調(diào)度策略類型的進(jìn)程,調(diào)度器是基于動態(tài)優(yōu)先級來調(diào)度的。動態(tài)優(yōu)先級跟屬性 nice 有關(guān),nice 的值會隨著進(jìn)程的運行時間而動態(tài)改變,以確保所有具有 SCHED_OTHER 策略的進(jìn)程公平地得到調(diào)度。
在 Linux 中,nice 的值范圍為-20 ~ +19,默認(rèn)值為 0。nice 值越大,則優(yōu)先級越低,因此相對較低 nice 值的進(jìn)程可以獲得更多的處理器時間。
通過命令 ps -el 查看系統(tǒng)中的進(jìn)程列表,其中 NI 列就是進(jìn)程對應(yīng)的 nice 值。
使用 top 命令,看到的 NI 列也是進(jìn)程的 nice 值。
調(diào)整 nice 值,可以通過 shell 命令 nice ,該命令可以按照指定的 nice 值運行 cmd ,命令的幫助信息為:
重新調(diào)整已運行進(jìn)程的 nice 值,可通過 renice 命令實現(xiàn),命令的幫助信息為:
另外,可以執(zhí)行 top 命令,輸入 r ,根據(jù)提示輸入進(jìn)程的 pid ,再輸入 nice 數(shù)值,也可以調(diào)整進(jìn)程的 nice 值。
SCHED_FIFO
該調(diào)度策略為先入先出調(diào)度策略,簡單概括,就是一旦進(jìn)程占用了 CPU,則一直運行,直到有更高優(yōu)先級的任務(wù)搶占,或者進(jìn)程自己放棄占用 CPU。
SCHED_RR
該調(diào)度策略為時間片輪轉(zhuǎn)調(diào)度策略,該調(diào)度策略是基于 SCHED_FIFO 策略的演進(jìn),其在每個進(jìn)程上增加一個時間片限制,當(dāng)時間片使用完成后,調(diào)度器將該進(jìn)程置于隊列的尾端,放在尾端保證了所有具有相同調(diào)度優(yōu)先級的進(jìn)程的調(diào)度公平。
使用 top 命令,如果 PR 列的值為 RT ,則說明該進(jìn)程采用的是實時調(diào)度策略,其調(diào)度策略為 SCHED_FIFO 或者 SCHED_RR,而對于非實時調(diào)度策略的進(jìn)程,該列的值為 NI + 20 。
可以通過命令 ps -eo state,uid,pid,ppid,rtprio,time,comm 來查看進(jìn)程對應(yīng)的實時優(yōu)先級,實時優(yōu)先級位于 RTPRIO 列下,如果進(jìn)程對應(yīng)的列顯示為 - ,說明該進(jìn)程不是實時進(jìn)程。
chrt 命令可以用來很簡單地更改進(jìn)程的調(diào)度策略與調(diào)度優(yōu)先級。在 Linux 下查看 chrt 命令的幫助信息:
比如,獲取某個進(jìn)程的調(diào)度策略,使用如下命令:
在比如,設(shè)置某個進(jìn)程的調(diào)度策略為 SCHED_FIFO,調(diào)度優(yōu)先級為 70,使用如下命令:
用top或者ps -l查看進(jìn)程會發(fā)現(xiàn)有PR(PRI) NI兩個字段:
NI 是優(yōu)先值,是用戶層面的概念, PR是進(jìn)程的實際優(yōu)先級, 是給內(nèi)核(kernel)看(用)的。
一般情況下,PR=NI+20, 如果一個進(jìn)程的優(yōu)先級PR是20, 那么它的NI(nice)值就是20-20=0。
進(jìn)程調(diào)度優(yōu)先級是從-20到19,一共40個級別,數(shù)字越大,表示進(jìn)程的優(yōu)先級越低。默認(rèn)時候,進(jìn)程的優(yōu)先級是0。查看進(jìn)程優(yōu)先級有兩個辦法:ps和top。top命令顯示的NI列的值?;蛘呖梢允褂胮s -efl來查看,也是在ni列表示了進(jìn)程的優(yōu)先級?!禠inux就該這么學(xué)》 一起學(xué)習(xí),進(jìn)程的優(yōu)先級可以在程序運行的時候設(shè)置,也可以在程序運行過程中動態(tài)的修改。
linux系統(tǒng)中,程序有若干個優(yōu)先級,最低的優(yōu)先級是19。
Linux為一套免費使用和自由傳播的類UNIX操作系統(tǒng),其內(nèi)核由林納斯·本納第克特·托瓦茲于1991年第一次釋出,它主要受到Minix和Unix思想的啟發(fā),是一個基于POSIX和Unix的多用戶、多任務(wù)、支持多線程和多CPU的操作系統(tǒng)。它能運行主要的Unix工具軟件、應(yīng)用程序和網(wǎng)絡(luò)協(xié)議。它支持32位和64位硬件
擴(kuò)展資料:
普通用戶只能在0~19之間調(diào)整應(yīng)用程序的優(yōu)先權(quán)值,只有超級用戶有權(quán)調(diào)整更高的優(yōu)先權(quán)值(從-20~19)。linux系統(tǒng)屬于這種數(shù)值越小優(yōu)先級越高,數(shù)值越大優(yōu)先級越低的系統(tǒng)。windows屬于那種優(yōu)先數(shù)值大的優(yōu)先級高的系統(tǒng)。
在linux系統(tǒng)中,使用ifconfig命令給網(wǎng)口配置baiip,系統(tǒng)會自動生成這個網(wǎng)卡的相關(guān)路由信息,可以使用命令route –n查看系統(tǒng)所有的路由信息,參數(shù)-n是不進(jìn)行地址解析,如果不添加-n選項,route命令會根據(jù)/etc/resolv文件中配置的DNS服務(wù)器進(jìn)行地址解析。