精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

談一談Linux讓實(shí)時(shí)/高性能任務(wù)獨(dú)占CPU的事

系統(tǒng) Linux
本文主要討論在高實(shí)時(shí)要求、高效能計(jì)算、DPDK等領(lǐng)域,Linux如何讓某一個(gè)線程排他性獨(dú)占CPU;獨(dú)占CPU涉及的線程、中斷隔離原理;以及如何在排他性獨(dú)占的情況下,甚至讓系統(tǒng)的timer tick也不打斷獨(dú)占任務(wù),從而實(shí)現(xiàn)最低的延遲抖動(dòng)。

[[380984]]

本文主要討論在高實(shí)時(shí)要求、高效能計(jì)算、DPDK等領(lǐng)域,Linux如何讓某一個(gè)線程排他性獨(dú)占CPU;獨(dú)占CPU涉及的線程、中斷隔離原理;以及如何在排他性獨(dú)占的情況下,甚至讓系統(tǒng)的timer tick也不打斷獨(dú)占任務(wù),從而實(shí)現(xiàn)最低的延遲抖動(dòng)。

本文目錄:

1. 工程需求

2. 用戶態(tài)隔離

3. 內(nèi)核態(tài)隔離

3.1 中斷

3.2 內(nèi)核線程

4. 最佳實(shí)踐指南

Part 1工程需求

在一個(gè)SMP或者NUMA系統(tǒng)中,CPU的數(shù)量大于1。在工程中,我們有時(shí)候有一種需求,就是讓某個(gè)能夠獨(dú)占CPU,這個(gè)CPU什么都不做,就只做指定的任務(wù),從而獲得低延遲、高實(shí)時(shí)的好處。

比如在DPDK中,通過設(shè)置

  1. GRUB_CMDLINE_LINUX_DEFAULT=“isolcpus=0-3,5,7” 

隔離CPU0,3,5,7,讓DPDK的任務(wù)在運(yùn)行的時(shí)候,其他任務(wù)不會(huì)和DPDK的任務(wù)進(jìn)行上下文切換,從而保證網(wǎng)絡(luò)性能最佳[1]。在Realtime應(yīng)用場(chǎng)景中,通過isolcpus=2隔離CPU2,然后把實(shí)時(shí)應(yīng)用通過taskset綁定到隔離的核:

  1. taskset-c 2 pn_dev 

從而保證低延遲要求[2]。

Part 2用戶態(tài)隔離

這個(gè)地方,我們可以看出,它們統(tǒng)一都使用了isolcpus這樣一個(gè)啟動(dòng)參數(shù)。

實(shí)踐是檢驗(yàn)真理的唯一標(biāo)準(zhǔn),下面我們來啟動(dòng)一個(gè)8核的ARM64系統(tǒng),運(yùn)行Ubuntu,并指定isolcpus=2這個(gè)啟動(dòng)參數(shù):

系統(tǒng)啟動(dòng)后,我們運(yùn)行下面簡(jiǎn)單的程序(啟動(dòng)8個(gè)進(jìn)程運(yùn)行while死循環(huán)):

我們是8核的,現(xiàn)在又是運(yùn)行8個(gè)進(jìn)程,所以理論上來講,負(fù)載均衡后,8個(gè)進(jìn)程應(yīng)該均分地運(yùn)行在8個(gè)核上面,但是我們來看看實(shí)際的htop結(jié)果:

我們發(fā)現(xiàn)3(也就是CPU2)上面的CPU占用率是0.0%。這實(shí)證了CPU2已經(jīng)被隔離,用戶空間的進(jìn)程不能在它上面跑。

當(dāng)然,這個(gè)時(shí)候,我們可以通過taskset,強(qiáng)行把其中的一個(gè)a.out,綁定到CPU2上面去:

從上面命令的結(jié)果看出,663原本的affinity list只有0,1,3-7是沒有2的,而我們強(qiáng)行把它設(shè)置為了2,之后再看htop,CPU2上面占用100%:

通過上面的實(shí)驗(yàn),我們明顯可以看出isolcpus=2使得CPU2上無法再運(yùn)行用戶空間的進(jìn)程了(除非手動(dòng)設(shè)置affinity)。

Part 3內(nèi)核態(tài)隔離

中斷

但是,能在CPU2上面運(yùn)行的,不是只有用戶態(tài)的任務(wù),還可以有內(nèi)核線程、中斷等,那么isolcpus=能否隔離內(nèi)核線程和中斷呢?

對(duì)于中斷,我們特別容易查看,就是實(shí)際去驗(yàn)證每個(gè)IRQ的smp_affinity就好了:

從上圖明顯可以看出,對(duì)于44、47號(hào)這種外設(shè)的中斷,Linux內(nèi)核把smp_affinity設(shè)置為了FB(11111011),明顯避開了CPU2,所以,實(shí)際外設(shè)中斷也不會(huì)在CPU2發(fā)生,除非我們強(qiáng)行給中斷綁核,比如讓44號(hào)中斷綁定到CPU2:

  1. echo 2 >/proc/irq/44/smp_affinity_list 

之后,我們發(fā)現(xiàn)44號(hào)中斷在CPU2可以發(fā)生:

但是,系統(tǒng)的timer中斷、IPI,由于是Linux系統(tǒng)的運(yùn)行基石,實(shí)際還是要在CPU2上面運(yùn)行的。這里面最可能給任務(wù)帶來延遲抖動(dòng)的,自然是timer tick。

下面我們重點(diǎn)探討下tick的問題,由于Linux一般情況下,已經(jīng)配置IDLE狀態(tài)的NO_HZ tickless,所以CPU2上面什么都不跑的時(shí)候,實(shí)際timer中斷幾乎不發(fā)生。

下面,我們還是在isolcpus=2的情況下,運(yùn)行前面那個(gè)8個(gè)進(jìn)程的a.out,默認(rèn)情況下沒有任務(wù)會(huì)占用CPU2。通過先后運(yùn)行幾次cat /proc/interrupts | head 2,我們會(huì)看到其他core的timer中斷頻繁發(fā)生,而CPU2幾乎不變,這顯然是IDLE時(shí)候的NO_HZ在發(fā)揮省電的作用:

但是,一旦我們放任務(wù)到CPU2,哪怕只是放1個(gè),就會(huì)發(fā)現(xiàn)CPU2上面的timer中斷開始增加:

這說明一點(diǎn),哪怕隔離的CPU上面只有一個(gè)線程去跑,timer tick就會(huì)開始跑,當(dāng)然,這個(gè)timer tick也會(huì)頻繁打斷這一個(gè)線程,從而造成大量的上下文切換。你肯定會(huì)覺得Linux怎么這么傻,既然只有一個(gè)人,那也沒有時(shí)間片分片的必要,不需要在2個(gè)或者多個(gè)任務(wù)進(jìn)行時(shí)間片劃分地調(diào)度,為啥還要跑tick?其實(shí)原因是我們的內(nèi)核默認(rèn)只是使能了IDLE的NO_HZ:

我們來重新編譯一個(gè)內(nèi)核,使能NO_HZ_FULL:

當(dāng)我們使能了NO_HZ_FULL后,Linux支持在CPU上僅有1個(gè)任務(wù)的時(shí)候,是可以NO_HZ的。但是有2個(gè)就傻眼了,所以這個(gè)“FULL”也不是真地FULL[3]。這當(dāng)然也可以理解,因?yàn)橛?個(gè)就涉及到時(shí)間片調(diào)度的問題。什么時(shí)候應(yīng)該使能NO_HZ_FULL,內(nèi)核文檔Documentation/timers/no_hz.rst有明確地“指示”,只有在實(shí)時(shí)和HPC等的場(chǎng)景,才需要,否則默認(rèn)的NO_HZ_IDLE是你最好的選擇:

我們重新編譯了內(nèi)核,選中了NO_HZ_FULL,下面啟動(dòng)Linux,注意啟動(dòng)的時(shí)候參數(shù)添加nohz_full=2,讓CPU2支持NO_HZ_FULL:

重新運(yùn)行CPU2只有一個(gè)任務(wù)的場(chǎng)景,看看它的timer中斷發(fā)生情況:

發(fā)現(xiàn)CPU2上面的tick穩(wěn)定在188上面,這樣相信你會(huì)更加開心,因?yàn)槟悛?dú)占地更加徹底了!

下面,我們?cè)俜乓粋€(gè)task進(jìn)去CPU2,有2個(gè)任務(wù)的情況下,CPU2上面的timer tick開始增加:

不過,這或許不是個(gè)問題,因?yàn)槲覀冋f好了“獨(dú)占”,1個(gè)任務(wù)獨(dú)占的時(shí)候,timer tick不來打擾,應(yīng)該已經(jīng)是非常理想的情況了!

內(nèi)核態(tài)線程

內(nèi)核態(tài)的線程其實(shí)和用戶態(tài)差不多,當(dāng)它們沒有綁定到隔離的CPU的時(shí)候,是不會(huì)跑到隔離CPU運(yùn)行的。下面用筆者在內(nèi)核里面添加的dma_map_benchmark來做實(shí)驗(yàn)[4],開啟16個(gè)內(nèi)核線程來進(jìn)行DMA map和unmap(注意我們只有8個(gè)核):

  1. ./dma_map_benchmark -s 120 -t 16 

我們看到CPU2上面的CPU占用也是0:

內(nèi)核里面的dma_map_benchmark線程在狂占CPU0-1, 3-7,但是就是不去占CPU2:

但是,內(nèi)核線程如果用kthread_bind_mask()類似API把線程綁定到了隔離的CPU,則情況就不一樣了,這就類似用taskset把用戶態(tài)的任務(wù)綁定到CPU一樣。

Part 4最佳實(shí)踐指南

對(duì)于實(shí)時(shí)性要求高、高性能計(jì)算等場(chǎng)景,如果要讓某個(gè)任務(wù)獨(dú)占CPU,最理想的選擇是:

1. 采用isolcpus隔離CPU

2. 將指定任務(wù)綁定到隔離CPU

3. 小心意外地把中斷、內(nèi)核線程綁定到了隔離CPU,排查到這些“意外”分子

4. 使能NO_HZ_FULL,則效果更佳,因?yàn)檫Btimer tick中斷也不打擾你了。

參考文獻(xiàn)

[1]http://doc.dpdk.org/spp-18.02/setup/performance_opt.html

[2]https://rt-labs.com/docs/p-net/linuxtiming.html

[3]https://lwn.net/Articles/549580/

[4]https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=65789daa80

https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7679325702

本文轉(zhuǎn)載自微信公眾號(hào)「Linux閱碼場(chǎng)」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系Linux閱碼場(chǎng)公眾號(hào)。

 

 

責(zé)任編輯:武曉燕 來源: Linux閱碼場(chǎng)
相關(guān)推薦

2015-03-27 15:07:55

云計(jì)算IaaS平臺(tái)Docker

2023-11-01 11:51:08

Linux性能優(yōu)化

2021-11-23 09:45:26

架構(gòu)系統(tǒng)技術(shù)

2024-03-18 13:43:20

Linux架構(gòu)

2021-02-19 09:19:11

消息隊(duì)列場(chǎng)景

2018-08-21 14:42:29

閃存存在問題

2021-07-28 20:12:17

WindowsHeap內(nèi)存

2023-11-01 11:59:13

2022-02-14 22:22:30

單元測(cè)試Junit5

2023-11-01 10:38:46

Linux高性能網(wǎng)絡(luò)編程

2023-11-01 11:40:46

Linux高性能網(wǎng)絡(luò)編程工具

2023-11-01 10:58:31

系統(tǒng)調(diào)用高性能網(wǎng)絡(luò)編程Linux

2023-11-01 11:27:10

Linux協(xié)程

2022-07-04 10:51:27

數(shù)據(jù)中臺(tái)數(shù)據(jù)倉庫

2014-07-17 10:11:53

Android LAPI谷歌

2022-11-10 08:16:19

java性能服務(wù)性能

2021-05-11 08:48:23

React Hooks前端

2017-11-21 14:32:05

容器持久存儲(chǔ)

2016-07-08 13:33:12

云計(jì)算

2020-12-04 11:40:53

Linux
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

黑森林av导航| 久久久久久久久久久久久久久久av| 亚洲精品91在线| 97在线观看免费高| 台湾成人免费视频| 最新热久久免费视频| 国产91视觉| 国产亚洲欧美在线精品| 欧美电影一二区| 精品国产人成亚洲区| 男人的天堂狠狠干| 夜级特黄日本大片_在线| 国产中文一区二区三区| 97视频在线观看免费高清完整版在线观看| www.黄色在线| 国产ts一区| 51久久夜色精品国产麻豆| 国产h视频在线播放| 嫩草在线视频| 久久理论电影网| 亚洲另类激情图| 8x拔播拔播x8国产精品| 久久人人九九| 欧美老熟妇乱大交xxxxx| 精品91福利视频| 色综合久久中文字幕| 国产日韩欧美大片| 搞黄视频免费在线观看| www.视频一区| 亚洲自拍偷拍色图| 伊人久久一区二区| 国产精品尤物| 欧美黑人国产人伦爽爽爽| 美国美女黄色片| 久久免费视频66| 日韩一级片在线观看| 欧美婷婷精品激情| xx欧美xxx| 精品久久久国产| 91网站在线观看免费| 久cao在线| 久久精品亚洲国产奇米99| 国产精品一区二区在线观看 | 蜜桃成人av| 亚洲婷婷综合色高清在线| 欧美日韩电影一区| 国产日韩av高清| caoporn国产| 日韩视频一区| 国内精品模特av私拍在线观看| 欧美三级黄色大片| 国产精品国产一区| 久久精品成人欧美大片古装| 中国美女黄色一级片| 久久精品国产亚洲夜色av网站| 亚洲片在线观看| 欧美做受xxxxxⅹ性视频| 亚洲精品推荐| 亚洲欧美激情另类校园| 中文字幕在线看高清电影| 欧美女王vk| 中文亚洲视频在线| 日本视频在线免费| 91精品国产91久久久久久密臀| 色噜噜亚洲精品中文字幕| 林心如三级全黄裸体| 91欧美在线| 欧美成人午夜免费视在线看片| 国模无码国产精品视频| 亚洲视频一区| 97视频在线免费观看| 亚洲婷婷综合网| 免费高清在线一区| 亚洲在线一区二区| 少妇av在线播放| 久久亚洲二区三区| 亚洲三区四区| 女囚岛在线观看| 欧美日韩在线视频首页| 国产视频一区二区视频| 天天综合91| 欧美精品一区视频| 人妻少妇无码精品视频区| 欧美综合久久| 欧美激情aaaa| 激情五月婷婷网| 狠狠色狠狠色综合日日91app| 成人做爰66片免费看网站| 天堂av网在线| 国产精品久久久99| 免费超爽大片黄| 日韩不卡在线| 日韩欧美资源站| 波多野结衣av在线免费观看| 日韩毛片视频| 国产综合在线视频| 一级成人免费视频| 成人毛片老司机大片| 日韩精品最新在线观看| 亚洲国产精品精华素| 狠狠操狠狠色综合网| 久久99999| 精品国产影院| 久久精品久久久久久国产 免费| 国产亚洲自拍av| 日本大胆欧美人术艺术动态| 翡翠波斯猫1977年美国| 福利小视频在线观看| 亚洲自拍与偷拍| 91热这里只有精品| 久久动漫网址| 久久中文字幕在线视频| 日本视频在线观看免费| 国产超碰在线一区| 伊人久久99| 中文字幕乱码在线播放| 日韩一二三区不卡| 大吊一区二区三区| 欧美一级久久| 国产精品久久一区二区三区| 一本一道波多野毛片中文在线| 精品久久久久久久久久久久久久| 九九久久久久久| 欧美视频免费| 欧洲美女7788成人免费视频| 亚洲av无码国产综合专区| 国产精品区一区二区三区| 毛片一区二区三区四区| www.成人网| 欧美成人亚洲成人日韩成人| 中文字幕有码视频| 久久久精品免费网站| 妞干网在线视频观看| 秋霞午夜一区二区三区视频| 色婷婷综合成人av| 天堂av免费在线观看| 久久日一线二线三线suv| 成人免费在线网| 视频一区中文字幕精品| 精品国产一区二区三区在线观看| 国产亚洲欧美在线精品| 91久色porny| 国产原创popny丨九色| 都市激情亚洲| 国内精品久久久久| 色窝窝无码一区二区三区成人网站| 亚洲精品国产第一综合99久久 | av男人的天堂在线观看| 日韩手机在线导航| 2021亚洲天堂| 国产激情视频一区二区三区欧美| 欧美日韩视频免费在线观看| 日本免费一区二区三区等视频| 伊人伊成久久人综合网小说| 草莓视频18免费观看| 国产亚洲美州欧州综合国 | 国产精品亚洲一区二区三区妖精| 咪咪色在线视频| 精品久久免费| 欧美大片在线看| 亚洲第一页在线观看| 夜夜嗨av一区二区三区网页| 国产chinesehd精品露脸| 四季av在线一区二区三区| 国产综合久久久久久| 美女隐私在线观看| 日韩精品资源二区在线| 黄色激情视频在线观看| 91在线视频网址| 嫩草av久久伊人妇女超级a| 久久精品不卡| 国产精品二区在线| 在线看的毛片| 中文字幕精品在线视频| 国产夫妻性生活视频| 亚洲国产精品麻豆| 亚洲最大成人网站| 捆绑调教一区二区三区| 精品国产三级a∨在线| 永久免费精品视频| 琪琪亚洲精品午夜在线| 在线视频自拍| 精品国产乱子伦一区| 国产高潮久久久| 国产精品欧美一区喷水| 欧美成人精品一区二区综合免费| 亚洲欧美激情诱惑| 在线无限看免费粉色视频| www.久久东京| 国产精品久久久久久网站| 18+激情视频在线| 亚洲欧洲第一视频| 国产www免费观看| 日韩欧美中文在线| 99久久99久久精品国产| www激情久久| 久久精品国产露脸对白| 香蕉久久夜色精品| 在线观看18视频网站| 亚洲精品无吗| 动漫美女被爆操久久久| 少妇精品视频一区二区免费看| 欧美久久久精品| 蜜桃视频在线观看网站| 日韩欧美成人激情| 91丨九色丨海角社区| 亚洲尤物视频在线| 99在线视频免费| 91原创在线视频| 午夜福利123| 欧美aaa在线| 国产极品尤物在线| 女生裸体视频一区二区三区| 欧美日韩中文国产一区发布| 欧美经典影片视频网站| 国产精品露脸自拍| 精精国产xxxx视频在线野外| 久久精品一本久久99精品| 久久精品a一级国产免视看成人| 欧美一区午夜视频在线观看| 少妇又紧又色又爽又刺激视频| 亚洲国产成人tv| 国产真实乱在线更新| 久久久www成人免费毛片麻豆| 绯色av蜜臀vs少妇| 国产在线精品一区二区夜色 | 国产成人av电影在线| 亚洲激情在线看| 麻豆精品一区二区三区| 99免费视频观看| 欧美亚洲自偷自偷| 日韩少妇内射免费播放| 亚洲手机视频| 成人一级生活片| 欧美二区不卡| 免费看污污视频| 亚洲激情五月| a级网站在线观看| 香蕉视频国产精品| 免费成人深夜夜行网站视频| 欧美3p在线观看| 亚洲午夜精品久久久久久浪潮| 欧美少妇xxxx| 亚洲欧美日韩综合一区| 俺要去色综合狠狠| 日日骚一区二区网站| 国产欧美日韩精品一区二区免费| 你懂的视频在线一区二区| 四虎影视精品| 欧美不卡在线一区二区三区| 亚洲精品进入| 日韩视频在线播放| 欧美日韩国产一区二区三区不卡| 台湾成人av| 久久婷婷蜜乳一本欲蜜臀| 尤物国产精品| 影视一区二区| 女人帮男人橹视频播放| 在线日韩视频| 99999精品视频| 久久综合网络一区二区| 男人天堂成人在线| 蜜桃av一区二区| 亚洲欧美aaa| 国产成人免费视频一区| 中文字幕第3页| 久久综合九色综合欧美98| 亚洲第一香蕉网| 国产精品不卡在线| 毛片aaaaa| 欧美日韩国产精品专区| 日韩美一区二区| 欧美日韩国产免费一区二区| 国产伦精品一区二区三区四区 | 亚洲美女91| 日本一本二本在线观看| 麻豆91在线看| 亚洲女则毛耸耸bbw| 久久综合狠狠综合久久综合88 | 嫩草在线播放| 丝袜美腿亚洲一区二区| 在线欧美三级| 欧美一级bbbbb性bbbb喷潮片| 成人午夜亚洲| 成人看片在线| 国产一区二区三区日韩精品| 国产成年人在线观看| 亚洲人体大胆视频| 亚洲欧美久久久久| 丁香婷婷综合五月| 国产又黄又粗视频| 一区二区三区蜜桃| 无码免费一区二区三区| 日韩欧美在线一区二区三区| 欧洲成人av| 欧美男插女视频| 五月激情久久| 成人在线看片| 欧美aaaaaaaaaaaa| 99精品人妻少妇一区二区| 久久99精品久久久久久国产越南 | 久久久国产午夜精品| 欧美又粗又大又长| 欧美在线一区二区三区| 免费av一级片| 欧美成人h版在线观看| 日韩伦理三区| 国产欧美日本在线| 亚洲一区二区三区| 日日噜噜夜夜狠狠| 91麻豆免费观看| 美女毛片在线观看| 欧美精品丝袜中出| 精品影院一区| 国产最新精品视频| 日韩一区二区三区在线看| 日韩欧美精品在线不卡| 日韩亚洲精品在线| avtt中文字幕| 亚洲欧美日韩国产成人精品影院 | 日本va欧美va欧美va精品| 国模无码视频一区| 亚洲另类中文字| 91高潮大合集爽到抽搐| 亚洲欧美中文字幕在线一区| 欧美大胆a人体大胆做受| 91手机在线观看| 久久精品久久久| 三级视频中文字幕| 国产欧美一区二区三区沐欲 | 久久福利精品| 制服丝袜在线第一页| 一区二区三区在线视频观看| 国产精品久久久久毛片| 最近2019中文字幕大全第二页 | 99re在线国产| 中文字幕免费精品| 波多野结衣免费观看| 综合电影一区二区三区| 一级做a爱片性色毛片| 在线视频一区二区| 精品九九久久| 亚洲一区三区视频在线观看 | 免费黄视频在线观看| 亚洲精品免费在线| 国产熟女一区二区丰满| 精品国偷自产在线| 欧美h版在线观看| 男女h黄动漫啪啪无遮挡软件| 另类小说一区二区三区| 国产免费一区二区三区四区| 欧美日本一区二区在线观看| 天堂а√在线资源在线| 91美女片黄在线观| 亚洲乱码精品| 国产人妖在线观看| 亚洲图片有声小说| 天天综合网天天综合| 欧美在线精品免播放器视频| 天堂资源在线亚洲| 免费黄色特级片| 亚洲国产精品99久久久久久久久 | 免费成人av资源网| 极品色av影院| 日韩一区二区在线看片| 欧美xxxx黑人又粗又长| 国产精品一区二区三区精品| 国产日韩欧美三级| 日本成人免费视频| 7777精品伊人久久久大香线蕉的 | 国产成人精品优优av| 欧美日韩伦理| 夜夜夜夜夜夜操| 亚洲精品国产无天堂网2021 | 妞干网视频在线观看| 91网站在线观看视频| 久久久久久av无码免费看大片| 精品国内产的精品视频在线观看| 精品国产乱码一区二区三区 | 波多野结衣在线网址| 精品少妇一区二区三区日产乱码| 成入视频在线观看| 日日噜噜噜噜夜夜爽亚洲精品| 国产主播一区二区三区| 国产免费观看av| 日韩一级黄色av| 国产成人澳门| 日日躁夜夜躁aaaabbbb| 樱桃视频在线观看一区| 日本大片在线观看| 成人a级免费视频| 国产日韩欧美一区在线| 欧美午夜激情影院| 日韩美女视频在线| 日韩成人亚洲| 日韩欧美视频免费在线观看| 久久你懂得1024| www.97超碰| 国产精品成人播放| 黄色免费成人|