成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳細剖析Linux進程調度時機

系統 Linux
Linux進程調度是一個叫Schedule()的函數來具體來完成的,它存在于Linux內核空間中。什么時候使用這個函數,具體時機是怎么樣的呢?

Linux在眾多進程中是怎么進行調度的,這個牽涉到Linux進程調度時機的概念,由Linux內核中Schedule()的函數來決定是否要進行進程的切換,如果要切換的話,切換到哪個進程等等。

Linux進程調度時機主要有

1、進程狀態轉換的時刻:進程終止、進程睡眠;

2、當前進程的時間片用完時(current->counter=0);

3、設備驅動程序

4、進程從中斷、異常及系統調用返回到用戶態時;

時機1,進程要調用sleep()或exit()等函數進行狀態轉換,這些函數會主動調用調度程序進行進程調度;

時機2,由于進程的時間片是由時鐘中斷來更新的,因此,這種情況和時機4是一樣的。

時機3,當設備驅動程序執行長而重復的任務時,直接調用調度程序。在每次反復循環中,驅動程序都檢查need_resched的值,如果必要,則調用調度程序schedule()主動放棄CPU。

時機4,如前所述,不管是從中斷、異常還是系統調用返回,最終都調用ret_from_sys_call(),由這個函數進行調度標志的檢測,如果必要,則調用調用調度程序。那么,為什么從系統調用返回時要調用調度程序呢?這當然是從效率考慮。從系統調用返回意味著要離開內核態而返回到用戶態,而狀態的轉換要花費一定的時間,因此,在返回到用戶態前,系統把在內核態該處理的事全部做完。

對于直接執行調度程序的時機,我們不討論,因為后面我們將會描述調度程序的工作過程。前面我們討論了時鐘中斷,知道了時鐘中斷的重要作用,下面我們就簡單看一下每個時鐘中斷發生時內核要做的工作,首先對這個最頻繁的調度時機有一個大體了解,然后再詳細討論調度程序的具體工作過程。

每個時鐘中斷(timer interrupt)發生時,由三個函數協同工作,共同完成進程的選擇和切換,它們是:schedule()、do_timer()及ret_form_sys_call()。我們先來解釋一下這三個函數:

schedule():進程調度函數,由它來完成進程的選擇(調度);

do_timer():暫且稱之為時鐘函數,該函數在時鐘中斷服務程序中被調用,是時鐘中斷服務程序的主要組成部分,該函數被調用的頻率就是時鐘中斷的頻率即每秒鐘100次(簡稱100赫茲或100Hz);

ret_from_sys_call():系統調用返回函數。當一個系統調用或中斷完成時,該函數被調用,用于處理一些收尾工作,例如信號處理、核心任務等等。

這三個函數是如何協調工作的呢?

前面我們看到,時鐘中斷是一個中斷服務程序,它的主要組成部分就是時鐘函數do_timer(),由這個函數完成系統時間的更新、進程時間片的更新等工作,更新后的進程時間片counter作為調度的主要依據。

在時鐘中斷返回時,要調用函數ret_from_sys_call(),前面我們已經討論過這個函數,在這個函數中有如下幾行:

cmpl $0, _need_resched

jne reschedule

……

restore_all:

RESTORE_ALL


reschedule:

call SYMBOL_NAME(schedule)

jmp ret_from_sys_call


這幾行的意思很明顯:檢測 need_resched 標志,如果此標志為非0,那么就轉到reschedule處調用調度程序schedule()進行進程的選擇。調度程序schedule()會根據具體的標準在運行隊列中選擇下一個應該運行的進程。當從調度程序返回時,如果發現又有調度標志被設置,則又調用調度程序,直到調度標志為0,這時,從調度程序返回時由RESTORE_ALL恢復被選定進程的環境,返回到被選定進程的用戶空間,使之得到運行。

以上就是時鐘中斷這個最頻繁的調度時機。討論這個的主要目的使讀者對時機4有個大致的了解。

***要說明的是,系統調用返回函數ret_from_sys_call()是從系統調用、異常及中斷返回函數通常要調用的函數,但并不是非得調用,對于那些要經常被響應的和要被盡快處理的中斷請求信號,為了減少系統開銷,處理完成后并不調用 ret_from_sys_call()(因為很顯然的,從這些中斷處理程序返回到的用戶空間肯定是那個被中斷的進程,無需重新選擇),并且,它們作的工作要盡可能少,因為響應的頻率太高了。

Linux進程調度和其他的UNIX進程調度不同,尤其是在“nice level”優先級的處理上,與優先權調度(priority高的進程***運行)不同,Linux用的是時間片輪轉調度(Round Robing),但同時又保證了高優先級的進程運行的既快、時間又長(both sooner and longer)。而標準的UNIX調度程序都用到了多級進程隊列。大多數的實現都用到了二級優先隊列:一個標準隊列和一個實時(“real time”)隊列。一般情況下,如果實時隊列中的進程未被阻塞,它們都要在標準隊列中的進程之前被執行,并且,每個隊列中,“nice level”高的進程先被執行。

總體上,Linux 調度序程在交互性方面表現很出色,當然了,這是以犧牲一部分“吞吐量”為代價的。

【編輯推薦】

  1. 綜述Linux Unix區別
  2. 詳細剖析Linux文件夾執行權限
  3. 怎么檢查Linux安全漏洞
  4. 詳細介紹Linux man命令的使用方法
  5. 詳述Linux bash快捷鍵的使用
責任編輯:小霞 來源: 互聯網
相關推薦

2021-12-15 15:03:51

Linux內核調度

2009-09-16 08:40:53

linux進程調度linuxlinux操作系統

2015-09-08 15:13:35

Android進程與線程

2010-03-04 17:36:01

Linux系統分區

2010-03-03 14:30:35

Linux睡眠休眠

2023-03-03 00:03:07

Linux進程管理

2009-10-23 17:35:16

linux進程管理

2010-03-08 09:09:48

2023-03-05 15:28:39

CFSLinux進程

2021-05-12 07:50:02

CFS調度器Linux

2010-03-05 16:54:47

2012-05-14 14:09:53

Linux內核調度系統

2012-04-10 09:53:15

2010-06-11 16:57:37

Linux 查看進程

2018-05-30 13:42:39

2009-12-11 09:42:54

Linux內核源碼進程調度

2009-12-11 09:47:23

Linux內核源碼進程調度

2009-08-27 17:14:36

C# Socket

2009-09-02 10:26:23

JSP和BEAN

2009-09-29 10:00:40

Spring AOP框
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区不卡 | 国产精品久久精品 | 亚洲综合一区二区三区 | 亚洲成人精品一区 | 成人在线观看免费 | 一级h片 | 欧美中文字幕一区 | 天堂一区在线观看 | 亚洲一区二区免费视频 | 97精品超碰一区二区三区 | 亚洲欧美日韩精品久久亚洲区 | 精品国产乱码久久久久久老虎 | 日本特黄a级高清免费大片 成年人黄色小视频 | h片在线看 | 狠狠av| 夜色www国产精品资源站 | 成人三区 | 羞羞视频在线观看 | 日本成人片在线观看 | 国产成人网 | 精品九九 | 久久91精品久久久久久9鸭 | 农村黄性色生活片 | 亚洲在线中文字幕 | 欧美一区二区三区 | 精品国产乱码久久久久久88av | 亚洲精品在线播放 | 日韩理论电影在线观看 | 欧美a级成人淫片免费看 | 天天干成人网 | 精产国产伦理一二三区 | 久久久久久高潮国产精品视 | 一区二区av | 日本一二区视频 | 国产视频观看 | 91中文字幕在线 | 最新午夜综合福利视频 | 日韩欧美国产一区二区 | 亚洲一区高清 | 91综合网| 国产精品亚洲成在人线 |