前言
最近研發的產品出了點小bug,最后查到根本原因是,其中一個進程A使用基於FIFO的實時進程優先級,而另一個進程B是使用普通調度的進程優先級,而A和B兩個進程是互相通信的,進程B會被餓死,而進程A也不能正常工作。分析問題過程中查找了一些資料,以下記錄一些特別注意的點。
Linux進程調度的三種策略
(1)SCHED_OTHER,分時調度策略
(2)SCHED_FIFO,實時調度策略,先到先服務
(3)SCHED_RR,實時調度策略,時間片輪轉
由於相關內容比較多,本人也末必比別人講得更清楚,關於進程調度更詳細的內容建議讀《深入理解Linux內核》,網上的很多內容都是從此而來,也不一定比這本書講得好。另可參考此鏈接
https://blog.csdn.net/maximuszhou/article/details/42042161
前面遇到bug的進程A就是使用SCHED_FIFO調度策略的,而進程B沒有經過設置,默認是SCHED_OTHER。
如何設置為實時進程
查找資料的時候發現有個鏈接問,為什么設置FIFO策略,但和預想的不一致。鏈接在此 http://ask.csdn.net/questions/254095
從代碼看是因為設置的方法不對,直接上代碼,可以設置進程和線程的調度策略
1 #include <stdio.h> 2 #include <stdlib.h> 3 #include <pthread.h> 4 #include <sched.h> 5 6 7 pid_t pid = getpid(); 8 struct sched_param param; 9 param.sched_priority = sched_get_priority_max(SCHED_FIFO); // 也可用SCHED_RR 10 sched_setscheduler(pid, SCHED_RR, ¶m); // 設置當前進程 11 pthread_setschedparam(pthread_self(), SCHED_FIFO, ¶m); // 設置當前線程
可以通過top命令查看進程是否成功,如果為"rt"表示是實時進程了。如果不成功,可能是權限問題,需要roo權限。
調整進程優先級
如果不調整調度策略,也可以提升進程優先級,使得進程得到更多的CPU,特別是交互式程序,用戶體檢更好。代碼很簡單,只需要調用nice(int n)函數即可。n的有效范圍是-20~19,數值越小表示優先級越高。具體內容不在此復制粘貼,還是看《深入理解Linux內核》比較靠譜。