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

Linux塊層多隊列之引入內核

系統 Linux
Linux塊設備多隊列機制在Linux3.13中引入,剛開始引入多隊列時是多隊列和單隊列并存。想研究多隊列,當然還是以原始patch的方式研究最靠譜了。

[[343347]]

本文轉載自微信公眾號「相遇Linux」,作者JeffXie。轉載本文請聯系相遇Linux公眾號。  

Linux塊設備多隊列機制在Linux3.13中引入,剛開始引入多隊列時是多隊列和單隊列并存。

想研究多隊列,當然還是以原始patch的方式研究最靠譜了。

patch原始代碼:

git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux-block.git

分支:linux-block/v3.10-blk-mq

首先過目一下多隊列架構:

 

以讀IO為例,單隊列和多隊列相同的執行路徑:

  1. read_pages() 
  2. ... 
  3.   blk_start_plug() /* 進程準備蓄流 */ 
  4.   mapping->a_ops->readpages() /* 蓄流 */ 
  5.   blk_finish_plug() /* 進程開始泄流 */ 
  6.  ... 
  7. io_schedule() 進程蓄流之后等待io完成 
  8. (在blk_mq_make_request()函數中request的數目大于或者等于16 
  9. request_count >= BLK_MAX_REQUEST_COUNT 
  10. 不需要調用io_schedule(),直接泄流到塊設備驅動) 

mapping->a_ops->readpages() 會一直調用q->make_request_fn()

  1. generic_make_request() 
  2.     q->make_request_fn() 調用blk_queue_bio()或者 
  3.     多隊列blk_queue_make_request() 
  4.       __elv_add_request() 

為什么引入多隊列:多隊列相對與單隊列來說,每個cpu上都有一個軟隊列(使用blk_mq_ctx結構表示)避免插入request的時候使用spinlock鎖,而且如今的高速存儲設備,比如支持nvme的ssd(小弟剛買了一塊,速度確實快),訪問延遲非常小,而且本身硬件就支持多隊列,(引入的多隊列使用每個硬件隊列hctx->delayed_work替換了request_queue->delay_work) 以前的單隊列架構已經不能榨干它的性能,而且成為了它的累贅,單隊列在插入request和泄流到塊設備驅動時,一直有request_queue上的全局spinlock鎖,搞得人們都想直接bypass塊層的沖動。

單隊列插入request時會使用request_queue上的全局spinlock鎖

  1. blk_queue_bio() 
  2.     ... 
  3.     spin_lock_irq(q->queue_lock); 
  4.     elv_merge() 
  5.     spin_lock_irq(q->queue_lock); 
  6.     ... 

單隊列泄流到塊設備驅動時也是使用request_queue上的全局spinlock鎖:

  1. struct request_queue *blk_alloc_queue_node() 
  2.   INIT_DELAYED_WORK(&q->delay_work, blk_delay_work); 
  3.  
  4. blk_delay_work() 
  5.   __blk_run_queue() 
  6.     q->request_fn(q); 

__blk_run_queue()函數必須在隊列鎖中,也就是spin_lock_irq(q->queue_lock);

  1. 281  * __blk_run_queue - run a single device queue 
  2.  282  * @q:  The queue to run 
  3.  283  * 
  4.  284  * Description: 
  5.  285  *    See @blk_run_queue. This variant must be called with the queue lock 
  6.  286  *    held and interrupts disabled. 
  7.  287  */      
  8.  288 void __blk_run_queue(struct request_queue *q) 
  9.  289 {        
  10.  290         if (unlikely(blk_queue_stopped(q))) 
  11.  291                 return
  12.  292  
  13.  293         __blk_run_queue_uncond(q); 
  14.  294 } 

多隊列插入request時沒有使用spinlock鎖:

  1. blk_mq_insert_requests() 
  2.   __blk_mq_insert_request() 
  3.     struct blk_mq_ctx *ctx = rq->mq_ctx; (每cpu上的blk_mq_ctx) 
  4.     list_add_tail(&rq->queuelist, &ctx->rq_list) 

多隊列泄流到塊設備驅動也沒有使用spinlock鎖:

  1. static int blk_mq_init_hw_queues() 
  2.   INIT_DELAYED_WORK(&hctx->delayed_work, blk_mq_work_fn); 
  3.  
  4.  708 static void blk_mq_work_fn(struct work_struct *work
  5.  709 {                
  6.  710         struct blk_mq_hw_ctx *hctx; 
  7.  711                  
  8.  712         hctx = container_of(work, struct blk_mq_hw_ctx, delayed_work.work); 
  9.  713         __blk_mq_run_hw_queue(hctx); 
  10.  714 } 
  11.  
  12. __blk_mq_run_hw_queue()   
  13.     沒有spinlock鎖 
  14.   q->mq_ops->queue_rq(hctx, rq); 執行多隊列上的->queue_rq()回調函數 

從下圖可以看出系統使用多隊列之后的性能提升:

(我自己沒測試過性能,憑客觀想象應該與下列圖相符:) )

 

責任編輯:武曉燕 來源: 相遇Linux
相關推薦

2023-05-15 08:58:41

塊設備驅動Linux

2023-03-28 15:51:20

2011-07-28 10:11:04

CPU開源Linux內核3.1

2020-11-12 18:08:05

JavaLinux多線程

2009-10-22 12:27:30

linux塊設備

2022-03-03 19:31:31

隊列算法Harmony

2020-12-31 07:14:07

Linux內核頁表

2021-04-15 05:51:25

Linux

2010-04-21 13:47:45

Unix內核

2010-11-04 15:32:05

SecSSM服務器安全網神

2021-03-06 22:41:06

內核源碼CAS

2010-01-21 11:23:49

Linux多線程同步消息隊列

2017-01-12 19:15:03

Linux內核調試自構proc

2023-03-01 23:56:11

2009-10-27 15:06:15

Linux內核啟動

2023-03-10 14:56:37

Linuxconnect系統

2023-03-01 23:53:30

Linuxshutdown進程

2017-06-23 13:35:43

Linux內核形式驗證

2021-09-06 17:50:09

內核態操作系統

2021-02-20 06:08:07

LinuxWindows內核
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品久久久久久久久久久久久 | 在线成人免费视频 | 人人澡视频| 密乳av | 亚洲午夜电影 | 久久国产综合 | 午夜精品久久久久久久久久久久久 | 美女一级黄 | 亚洲免费在线播放 | 天堂av中文在线 | 综合久久99 | 91久久| 龙珠z在线观看 | 国产三级大片 | 大乳boobs巨大吃奶挤奶 | 精品毛片| 国产精品久久久久久中文字 | 精品久久精品 | 久久99久久99久久 | av午夜电影 | 国产视频中文字幕 | 国产中文字幕在线 | 伊人影院99| 成人精品在线观看 | 天天操人人干 | 国产资源在线视频 | 色视频www在线播放国产人成 | 日韩不卡在线 | 国产一区久久久 | 精品国产一区二区三区久久久蜜月 | 中文字幕乱码视频32 | 一级黄色录像毛片 | 国产99视频精品免费播放照片 | 毛片综合 | 精品视频一区二区三区在线观看 | 91久久国产综合久久 | 天天人人精品 | 日韩综合 | 免费黄色大片 | 国产成人免费在线观看 | 在线āv视频 |