真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

tgt程序框架知識點有哪些

這篇文章主要介紹“tgt程序框架知識點有哪些”,在日常操作中,相信很多人在tgt程序框架知識點有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”tgt程序框架知識點有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

專注于為中小企業(yè)提供成都網(wǎng)站制作、做網(wǎng)站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)七星免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。

tgt程序框架

tgt是用戶態(tài)實現(xiàn)的iscsi target,而iet(iscsi enterprise target)是在內(nèi)核態(tài)實現(xiàn)的target,tgt相比于iet來說,因為其用戶態(tài)實現(xiàn),方便調(diào)試,新加入一些功能等,不過性能相比iet來說要稍差一點。下面就介紹一下tgt的程序框架(略過iscsi協(xié)議解析處理部分),以便于整體把握tgt的代碼,方便后續(xù)的一些修改。

1.整體框架


tgt中命令的操作,與initiator端的通信都是通過epoll來實現(xiàn)的,下面分別對這兩部分進行說明。

1.1 tgtadm與tgtd的交互

在啟動tgtd進程的時候,就會初始化一個unix socket,將該fd加到epoll中,監(jiān)聽EPOLLIN事件,后續(xù)每執(zhí)行一條tgtadm命令,就會使用這個unix socket來和tgtd通信。
當在命令行里敲一條tgtadm命令時,通過unix socket發(fā)起請求,就會觸發(fā)epoll 的EPOLLIN事件,tgtd端accept,將連接fd加到epoll中,并注冊回調(diào)函數(shù)mtask_recv_send_handler,返回連接建立的響應給tgtadm端,然后tgtadm命令觸發(fā)EPOLLIN事件,tgtd端調(diào)用mtask_recv_send_handler,根據(jù)不同的mode調(diào)用不同的處理函數(shù)進行處理(這里有sys_mgmt/target_mgmt/portal_mgmt等),處理完后,將事件改為EPOLLIN|EPOLLOUT,然后發(fā)送響應給tgtadm端。

1.2 initiator與tgtd的交互

tgtd進程在啟動的時候就會創(chuàng)建一個socket,用于監(jiān)聽initiator的請求(具體是iscsi_tcp_init_portal函數(shù)中的處理),將該socket加到epoll中,注冊回調(diào)函數(shù)accept_connection。
initiator端的請求到來時,將新連接的fd加到epoll中,并注冊回調(diào)函數(shù)iscsi_tcp_event_handler,然后當收到EPOLLIN事件時,會調(diào)用iscsi_rx_handler進行iscsi請求的一些解析處理操作,并調(diào)用backing store的接口進行io的操作,操作完成后,修改事件為EPOLLLOUT,就會觸發(fā)調(diào)用到iscsi_tx_handler來發(fā)送響應給initiator。

1.3 函數(shù)調(diào)用棧

下面給出了iscsi_rx_handler的一些函數(shù)調(diào)用棧關系,其中涉及到與backing store中io處理接口的調(diào)用關系。2. backing store

tgt支持多種后端存儲,比如rdwr,aio,sg,rbd,sheepdog等,默認的是rdwr,可以指定flag(O_SYNC|O_DIRECT)。了解清楚tgt的后端存儲的處理模式,就可以添加新的后端存儲用于支持自定義的功能。

其中主要的接口就是bs_open,bs_init,bs_cmd_submit,bs_close,bs_exit。
bs_open和bs_init就是做創(chuàng)建lun時的一些初始化操作,比如打開設備文件,創(chuàng)建處理現(xiàn)線程,注冊處理回調(diào)函數(shù)等。
bs_cmd_submit:io請求到來時就會調(diào)用該函數(shù)進行處理。
bs_close和bs_exit就是刪除lun的時候做一些銷毀操作。
BS中支持同步和異步io兩種模式(rdwr就是同步的,aio就是異步的),下面分別介紹這兩種模式。

2.1 同步io


在同步io中,每個lun都會對應一個請求隊列(pending_list),在bs_init時就會創(chuàng)建多個線程(目前新版本一個lun默認16個線程)。新請求到來時,調(diào)用bs_cmd_submit將請求添加到pending_list中,多個線程共享這個pending_list,分別從pending_list中取請求來進行處理。當沒有請求時,這些線程就會等待在pending_list上,有新請求加入到pending_lsit后,就會喚醒等待的線程來進行處理。

2.2 異步io(aio)

tgt使用的是linux native aio來實現(xiàn)的,使用eventfd創(chuàng)建的fd將aio上下文和epoll聯(lián)系起來。(具體可以參考aio與epoll結合起來如何使用的一些資料)。下面是一些具體的處理邏輯。
1)bs_aio_open:io_setup建立異步io上下文 ,然后afd=eventfd() ,將afd加到epoll中(回調(diào)函數(shù)bs_aio_get_completions) ,并且afd與aio的上下文關聯(lián)。
2)bs_aio_cmd_submit:IO到來時調(diào)用,先把請求加到cmd_wait_list中,然后遍歷list,確定此次能提交的io數(shù)并初始化iocb(因為限制了aio的最大處理個數(shù)為128,有些io還在處理中,當前提交的aio個數(shù)就有限),然后使用io_submit提交一批異步io。
3)IO處理完后,會通過afd觸發(fā)EPOLLIN事件,調(diào)用回調(diào)函數(shù)bs_aio_get_completions進行處理,先read出當前完成的io數(shù),然后調(diào)用
io_getevents()獲取出已完成io的信息,然后對每個完成的io調(diào)用bs_aio_comlete_one做一些結束的處理(修改處理狀態(tài)),在這個函數(shù)中調(diào)用target_cmd_io_done,在target_cmd_io_done中會修改epoll的事件為EPOLLIN|EPOLLOUT,這樣就會觸發(fā)了EPOLLOUT事件,調(diào)用iscsi_tcp_event_handler,在這個函數(shù)里判斷如果是EPOLLOUT,就會調(diào)用iscsi_tx_handler來發(fā)送響應。

到此,關于“tgt程序框架知識點有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
分享題目:tgt程序框架知識點有哪些
當前URL:http://weahome.cn/article/pcecih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部