Linux 任務調度策略

🌟 概述

Linux 內核以線程(任務)為單位進行調度,支持 SCHED_FIFO 和 SCHED_RR(實時調度)以及 SCHED_OTHER(基于 CFS,非實時調度)。

🔍 調度策略

1. SCHED_FIFO(先進先出)

  • 機制:按優先級和到達順序運行,無時間片,直到阻塞、被搶占或終止。
  • 特點:優先級 1-99,低延遲,適合硬實時任務。
  • 場景:音頻處理、工業控制。

2. SCHED_RR(輪轉法)

  • 機制:同優先級線程按時間片輪轉,用盡后重新排隊。
  • 特點:優先級 1-99,平衡實時性和公平性。
  • 場景:視頻流、實時通信。

3. SCHED_OTHER(CFS)

  • 機制:基于 vruntime 公平調度,動態分配 CPU 時間。
  • 特點:nice 值 -20 到 19,適合非實時任務。
  • 場景:Web 服務器、桌面應用。

📊 調度策略對比

特性SCHED_FIFOSCHED_RRSCHED_OTHER (CFS)
類型實時實時非實時
調度單位線程線程線程
調度方式先進先出時間片輪轉vruntime 公平分配
時間片固定(10-100ms)動態調整
優先級1-991-99nice 值 -20 到 19
場景硬實時(如音頻)軟實時(如多媒體)通用任務(如服務器)
權限需 root需 root無需權限
風險低優先級線程可能被餓死時間片切換增加延遲不適合實時任務

🛠? 主要 API

  • sched_setscheduler(pid, policy, param):設置線程策略和優先級。
  • sched_getscheduler(pid):查詢線程策略。
  • sched_setparam(pid, param):設置優先級(SCHED_OTHER 忽略)。
  • sched_yield():讓出 CPU。
  • 結構struct sched_param { int sched_priority; };

?? 注意

  • SCHED_FIFO/RR 需 root 權限,優先級高于 SCHED_OTHER。
  • SCHED_OTHER 使用 nice 值調整優先級。
  • SCHED_FIFO 高優先級線程可能導致低優先級線程被餓死。

? 優點

  • SCHED_FIFO:低延遲,硬實時。
  • SCHED_RR:實時與公平平衡。
  • SCHED_OTHER:公平,適合通用任務。

🚫 局限性

  • SCHED_FIFO:可能餓死低優先級線程。
  • SCHED_RR:切換開銷。
  • SCHED_OTHER:不適合實時。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84411.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84411.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84411.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

芯片金屬層M1、M2區別

在芯片設計中,M1(第一層金屬)和 M2(第二層金屬)是常見的金屬層,它們在用途、布線方向、設計規則和應用場景等方面存在一些主要區別。以下是詳細對比: 1. 用途 M1(第一層金屬&#x…

Linux離線環境下安裝Lean 4開發環境的完整指南

文章目錄 一、準備工作1. 在線環境下載必要文件2. 傳輸文件至離線環境 二、安裝elan工具鏈管理器1. 解壓并安裝elan2. 配置環境變量3. 驗證elan安裝 三、安裝Lean 4二進制包1. 解壓Lean 4二進制文件2. 注冊工具鏈到elan 四、安裝VS Code Lean 4插件1. 使用VS Code界面安裝插件 …

ffmpeg windows 32位編譯

ffmpeg windows 32位編譯 編譯后程序下載 編譯方式 自動編譯工具套件 – https://github.com/m-ab-s/media-autobuild_suite github克隆完成后,雙擊bat文件打開編譯窗口,注意git檢出的目錄需要簡短,最好選一個盤的根目錄。 選擇編譯版本…

P1216 [IOI 1994] 數字三角形 Number Triangles

題目描述 觀察下面的數字金字塔。 寫一個程序來查找從最高點到底部任意處結束的路徑,使路徑經過數字的和最大。每一步可以走到左下方的點也可以到達右下方的點。 在上面的樣例中,從 7 → 3 → 8 → 7 → 5 7 \to 3 \to 8 \to 7 \to 5 7→3→8→7→5 的…

(二)原型模式

原型的功能是將一個已經存在的對象作為源目標,其余對象都是通過這個源目標創建。發揮復制的作用就是原型模式的核心思想。 一、源型模式的定義 原型模式是指第二次創建對象可以通過復制已經存在的原型對象來實現,忽略對象創建過程中的其它細節。 ?? 核心特點: 避免重復初…

Css實現懸浮對角線邊框動效

動畫效果展示 鼠標懸停時,一個帶有圓角的水綠色邊框會從右上和左下兩個方向快速展開,隨后顏色緩慢填充;移出鼠標時顏色先褪去,邊框再快速收縮消失,形成具有節奏感的呼吸式動畫。 📜 動畫原理說明 一、核…

技術創新究竟包含什么?

技術創新指的是引入新技術或改進現有技術,以創造新穎且更優的產品、服務或流程的過程。它涉及應用科學和技術知識開發創新解決方案,以創造價值、提高效率、推動增長,并滿足用戶和客戶不斷變化的需求。 技術創新可以有多種形式,例…

ArcGIS+AI:涵蓋AI大模型應用、ArcGIS功能詳解、Prompt技巧、AI助力的數據處理、空間分析、遙感分析、二次開發及綜合應用等

🌐 GIS憑借其強大的空間數據處理能力、先進的空間分析工具、靈活的地圖制作與可視化功能,以及廣泛的擴展性和定制性,已成為地理信息科學的核心工具。它在城市規劃、環境科學、交通管理等多個學科領域發揮著至關重要的作用。與此同時&#xff…

數據淘金時代:公開爬取如何避開法律雷區?

首席數據官高鵬律師團隊編著 一、“數字淘金熱”里的暗礁:那些被爬垮的平臺和賠哭的公司 前陣子某電商平臺的“商品比價爬蟲”上了熱搜,技術小哥本想靠抓競品數據優化定價,結果收到法院傳票——對方服務器被爬癱瘓,索賠300萬。這…

在ARM 架構的 Mac 上 更新Navicat到17后連接Oracle時報錯:未加載 Oracle 庫。

一:問題 使用的M1芯片的Mac,將Navicat更新到了17版本后,原本正常的Oracle數據庫無法連接,報錯:未加載 Oracle 庫。而sqlserver庫可以正常連接 二:解決方法 打開聚焦搜索——〉打開訪達——〉在應用程序中…

Springboot仿抖音app開發之用短視頻務模塊后端復盤及相關業務知識總結

Springboot仿抖音app開發之用戶業務模塊后端復盤及相關業務知識總結 BO類和VO類的區別 BO (Business Object) - 業務對象 定義: 業務對象是包含業務邏輯的領域模型用途: 主要用于封裝業務邏輯相關的數據,在業務層(Service層)之間傳遞特點: 與業務處理密切相關通常…

SQL-事務(2025.6.6-2025.6.7學習篇)

1、簡介 事務是一組操作的集合,它是一個不可分割的工作單位,事務會把所有的操作作為一個整體一起向系統提交或撤銷操作請求,即這些操作要么同時成功,要么同時失敗。 默認MySQL的事務是自動提交的,也就是說&#xff0…

《Ansys SIPI仿真技術筆記》 E-desk IBIS模型導入

技術筆記日期:20250611 00 背景和疑問 當在Circuit中準備載入IBIS時,工作界面會彈出如下界面: 那么具體Pin Import和Buffer Import有和區別? 何時該按哪個導入呢? 01 思考和記錄 1. Buffer Import VS Pin Import…

uniapp的請求封裝,如何避免重復提交請求

1、如何封裝uniapp,并且如何使用uniapp的封裝查看👉uniapp請求封裝_uni-app-x 請求封裝-CSDN博客??????? 2、聲明一個請求記錄的緩存,代碼如下 // 存儲請求記錄 let requestRecords {}; // 重復請求攔截時間(毫秒&#x…

【云原生】阿里云SLS日志自定義字段標簽實現日志告警

把業務日志接入到阿里云SLS日志服務后,我們想自定義字段做為標簽,在做日志告警的時候,可以做為查詢結果使用 自定義標簽 樣例: 一個典型的java log初始化日志格式 [ywgy-app-service:10.10.6.100:30000] 2025-06-10 08:40:53.444 INFO 1[TID: N/A][uId:][sId:][tId:][po…

Linux下制作Nginx綠色免安裝包

linux下安裝nginx比較繁瑣,遇到內網部署環境更是麻煩。根據經驗將nginx打包一個綠色版進行使用。 大體思路,在一臺正常的機器上面制造好安裝包,然后上傳到內網服務器,解壓使用 安裝包制作 安裝依賴 yum install gcc-c pcre per…

腦機新手指南(七):OpenBCI_GUI:從環境搭建到數據可視化(上)

一、OpenBCI_GUI 項目概述 (一)項目背景與目標 OpenBCI 是一個開源的腦電信號采集硬件平臺,其配套的 OpenBCI_GUI 則是專為該硬件設計的圖形化界面工具。對于研究人員、開發者和學生而言,首次接觸 OpenBCI 設備時,往…

【Zephyr 系列 18】分布式傳感網絡系統設計:從 BLE Mesh 到邊緣網關的數據閉環

??關鍵詞:Zephyr、BLE Mesh、邊緣網關、分布式網絡、狀態同步、組播、數據聚合、遠程控制 ??適合人群:希望實現 BLE Mesh 與網關聯合控制、多設備組網協作、數據閉環采集的開發者 ??預計字數:5500+ 字 ?? 背景與系統目標 在工業、農業、倉儲等場景中,我們常見以下…

【區塊鏈基礎】區塊鏈的 Fork(分叉)深度解析:原理、類型、歷史案例及共識機制的影響

區塊鏈的 Fork(分叉)全面解析:原理、類型、歷史案例及共識機制的影響 在區塊鏈技術的發展過程中,Fork(分叉)現象是不可避免且極具影響力的一個環節。理解區塊鏈分叉的形成原因、具體表現以及共識機制對分叉的作用,對于深入把握區塊鏈技術架構及其治理機制至關重要。 本…

開源 java android app 開發(十一)調試、發布

文章的目的為了記錄使用java 進行android app 開發學習的經歷。本職為嵌入式軟件開發,公司安排開發app,臨時學習,完成app的開發。開發流程和要點有些記憶模糊,趕緊記錄,防止忘記。 相關鏈接: 開源 java an…