linux中進程有優先權。 Linux是一個多用戶、多任務的作業系統,系統中通常運行著非常多的進程,但CPU在一個時鐘週期內只能運算一條指令;哪個進程應該先運算,誰應該後運算呢?這就需要由進程的優先權來決定了。在Linux系統中,表示進程優先權的有兩個參數:Pri和Nice;行程優先權是PRI值不是Nice值,但是Nice值會影響優先權。
本教學操作環境:linux7.3系統、Dell G3電腦。
Linux-進程的優先權
Linux 是一個多用戶、多任務的作業系統,系統中通常運行著非常多的進程。但是CPU 在一個時脈週期內只能運算一條指令(現在的CPU 採用了多執行緒、多核心技術,所以在一個時脈週期內可以運算多條指令。 但是同時運算的指令數也遠小於系統中的進程總數),那問題來了:誰該先運算,誰該後運算呢?這就需要由進程的優先權來決定了。
cpu分配資源的先後順序就是優先權
#優先權高的行程有優先執行的權利,
可以讓行程運行在指定的cpu上,改善系統整體效能
#另外,CPU 在運算資料時,不是把一個整合算完成,再進行下一個進程的運算,而是先運算進程1,再運算進程2,接下來運算進程3,然後再運算進程1,直到進程任務結束。不僅如此,由於進程優先權的存在,進程並不是依次運算的,而是哪個進程的優先權高,哪個進程會在一次運算循環中被更多次地運算。
這樣說很難理解,我們換個說法。假設我現在有4 個孩子(進程)需要餵飯(運算),我更喜歡孩子1(進程1 優先級更高),孩子2、孩子3 和孩子4 一視同仁(進程2、進程3 和進程4 的優先順序一致)。現在我開始餵飯了,我不能先把孩子 1 餵飽,再餵其他的孩子,而是需要循環餵飯(CPU 運算時所有進程循環運算)。那麼,我在餵飯時(運算),會先餵孩子 1 一口飯,然後再去餵其他孩子。而且在一次循環中,先餵孩子 1 兩口飯,因為我更喜歡孩子 1(優先級高),而餵其他的孩子一口飯。這樣,孩子 1 會先吃飽(進程 1 運算得更快),因為我比較喜歡孩子 1。
檢視進程優先權
#1.使用ps-al,可以看行程的優先權
#2.PRI和NI
在Linux 系統中,表示進程優先權的有兩個參數:Priority 和Nice。
[root@localhost ~]# ps -le F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD 4 S 0 1 0 0 80 0 - 718 - ? 00:00:01 init 1 S 0 2 0 0 80 0 - 0 - ? 00:00:00 kthreadd ...省略部分输出...
其中,PRI 代表 Priority,NI 代表 Nice。這兩個值都表示優先權,數值越小代表該行程越優先被 CPU 處理。不過,PRI值是由核心動態調整的,使用者不能直接修改。所以我們只能透過修改 NI 值來影響 PRI 值,間接地調整進程優先權。
PRI 和NI 的關係如下:
PRI (最終值) = PRI (原始值) NI
其實,大家只需要記得,我們修改NI 的值就可以改變進程的優先權即可。 NI 值越小,進程的 PRI 就會降低,該進程就越優先被 CPU 處理;反之,NI 值越大,進程的 PRI 值就會増加,該進程就越靠後被 CPU 處理。
修改 NI 值時有幾個注意事項:
NI 範圍是 -20~19。
一般使用者調整 NI 值的範圍是 0~19,而且只能調整自己的流程。
一般使用者只能調高 NI 值,而不能降低。如原本 NI 值為 0,則只能調整為大於 0。
只有 root 使用者才能設定行程 NI 值為負值,而且可以調整任何使用者的進程。
檢視檢視並修改nice值的指令
1.用top指令檢視並修改nice值
輸入top-按r ,輸入行程pid,輸入nice值。 (如果顯示拒絕提升的話,使用sudo提升top指令的權限)。
2.其他概念
競爭性:系統數目很多,但只有cpu數量少,甚至只有一個,所以進程之間是具有競爭屬性的。為了有效率地完成任務,更合理競爭相關資源,便具備了優先順序。
獨立性:多進程運行,需要獨享各種資源,所以多進程期間互不干擾。
並行:多個行程在多個cpu中進行,同時進行運行,稱為並行。
並發:多個進程在一個cpu上採用進程切換的方式,在一段時間內,讓多個進程得以推進,稱為並發。
進程優先權是PRI 值不是Nice 值,但Nice 值會影響優先權
PRI 也還是比較好理解的,即進程的優先權,或者通俗點說就是程式被CPU 執行的先後順序,此值越小進程的優先級越高。那 NI 呢?就是我們要說的 nice 值了,其表示進程可被執行的優先權的修正數值。如前面所說, PRI 值越小越快被執行,那麼加入 nice 值後,將會使得 PRI 變成: PRI(new)=PRI(old) nice 。
到目前為止,更需要強調一點的是,行程的 nice 值不是行程的優先權,他們不是一個概念,但是行程 nice 值會影響到行程的優先權變更。
透過調整 nice 值,更改行程優先權, nice 調整範圍是 -20~19 。
進程優先權與變動影響因素與原理
調度策略: RR 調度與FIFO 調度的進程屬於即時進程,以分時調度( OTHER )的進程是非即時進程。
FIFO (先進先出)和RR (時間片輪轉)用於實時進程, OTHER (分時調度)用於非實時進程;實時進程會搶佔普通進程; FIFO 會導致同優先權即時進程始終佔用CPU , RR 會保證同優先權即時進程按時間片輪流執行。
即時進程優先權高於普通進程,即時進程使用靜態優先權調度、非即時進程使用動態優先權調度,非即時進程動態優先權透過 nice 調整、可能受 bonus 影響。
Linux進程有兩種優先權:普通進程優先權(使用SCHED_NORMAL 排程策略),以及即時行程優先權(使用SCHED_FIFO 或SCHED_RR 排程策略)
#不同排程策略的即時進程只有在相同優先權時才有可比性,任何時候,實時進程的優先權都高於普通進程
Linux對實時進程使用靜態優先權調度,對普通的進程(非實時進程),根據動態優先權進行調度。
即時進程,只有靜態優先權(在0~MAX_RT_PRIO-1 間,預設MAX_RT_PRIO 為100 ), 核心不會再根據休眠等因素對其靜態優先權做調整;
即時行程0-99 號優先權每一個優先權對應一個優先權佇列(鍊錶),先執行數值高的對應的鍊錶(0號最低),可由後面所述的chrt 以及對應函數修改該優先權;
非即時行程靜態優先權可透過nice 值( -20~19 )調整: static_prio=MAX_RT_PRIO nice 20 。
nice 只影響非即時行程(靜態優先權在 100~139 之間), nice 越大靜態優先權值越大,優先權越低。
非即時進程動態優先權根據靜態優先權和bonus 計算: dynamic_prio = max (100, min (static_prio - bonus 5, 139))
bonus 反映進程平均睡眠時間(範圍0~10 ),睡眠時間越多越可能是交互進程,每次輪到它運行時它就越可能不會使用完時間片再釋放cpu 。
相關推薦:《Linux影片教學》
以上是linux中進程有優先權的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Linux系統管理和維護的關鍵步驟包括:1)掌握基礎知識,如文件系統結構和用戶管理;2)進行系統監控與資源管理,使用top、htop等工具;3)利用系統日誌進行故障排查,借助journalctl等工具;4)編寫自動化腳本和任務調度,使用cron工具;5)實施安全管理與防護,通過iptables配置防火牆;6)進行性能優化與最佳實踐,調整內核參數和養成良好習慣。

Linux維護模式通過在啟動時添加init=/bin/bash或single參數進入。 1.進入維護模式:編輯GRUB菜單,添加啟動參數。 2.重新掛載文件系統為讀寫模式:mount-oremount,rw/。 3.修復文件系統:使用fsck命令,如fsck/dev/sda1。4.備份數據並謹慎操作,避免數據丟失。

本文探討如何在Debian系統上提升Hadoop數據處理效率。優化策略涵蓋硬件升級、操作系統參數調整、Hadoop配置修改以及高效算法和工具的運用。一、硬件資源強化確保所有節點硬件配置一致,尤其關注CPU、內存和網絡設備性能。選擇高性能硬件組件對於提升整體處理速度至關重要。二、操作系統調優文件描述符和網絡連接數:修改/etc/security/limits.conf文件,增加系統允許同時打開的文件描述符和網絡連接數上限。 JVM參數調整:在hadoop-env.sh文件中調整

本指南將指導您學習如何在Debian系統中使用Syslog。 Syslog是Linux系統中用於記錄系統和應用程序日誌消息的關鍵服務,它幫助管理員監控和分析系統活動,從而快速識別並解決問題。一、Syslog基礎知識Syslog的核心功能包括:集中收集和管理日誌消息;支持多種日誌輸出格式和目標位置(例如文件或網絡);提供實時日誌查看和過濾功能。二、安裝和配置Syslog(使用Rsyslog)Debian系統默認使用Rsyslog。您可以通過以下命令安裝:sudoaptupdatesud

選擇適合Debian系統的Hadoop版本,需要綜合考慮以下幾個關鍵因素:一、穩定性與長期支持:對於追求穩定性和安全性的用戶,建議選擇Debian穩定版,例如Debian11(Bullseye)。該版本經過充分測試,擁有長達五年的支持週期,能夠確保系統穩定運行。二、軟件包更新速度:如果您需要使用最新的Hadoop功能和特性,則可以考慮Debian的不穩定版(Sid)。但需注意,不穩定版可能存在兼容性問題和穩定性風險。三、社區支持與資源:Debian擁有龐大的社區支持,可以提供豐富的文檔和

本文介紹如何在Debian系統上使用TigerVNC共享文件。你需要先安裝TigerVNC服務器,然後進行配置。一、安裝TigerVNC服務器打開終端。更新軟件包列表:sudoaptupdate安裝TigerVNC服務器:sudoaptinstalltigervnc-standalone-servertigervnc-common二、配置TigerVNC服務器設置VNC服務器密碼:vncpasswd啟動VNC服務器:vncserver:1-localhostno

配置Debian郵件服務器的防火牆是確保服務器安全性的重要步驟。以下是幾種常用的防火牆配置方法,包括iptables和firewalld的使用。使用iptables配置防火牆安裝iptables(如果尚未安裝):sudoapt-getupdatesudoapt-getinstalliptables查看當前iptables規則:sudoiptables-L配置

在Debian郵件服務器上安裝SSL證書的步驟如下:1.安裝OpenSSL工具包首先,確保你的系統上已經安裝了OpenSSL工具包。如果沒有安裝,可以使用以下命令進行安裝:sudoapt-getupdatesudoapt-getinstallopenssl2.生成私鑰和證書請求接下來,使用OpenSSL生成一個2048位的RSA私鑰和一個證書請求(CSR):openss


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

Dreamweaver CS6
視覺化網頁開發工具