您好,登錄后才能下訂單哦!
這篇文章主要介紹“tgt程序框架知識點有哪些”,在日常操作中,相信很多人在tgt程序框架知識點有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”tgt程序框架知識點有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
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ù)的一些修改。
tgt中命令的操作,與initiator端的通信都是通過epoll來實現(xiàn)的,下面分別對這兩部分進(jìn)行說明。
在啟動tgtd進(jìn)程的時候,就會初始化一個unix socket,將該fd加到epoll中,監(jiān)聽EPOLLIN事件,后續(xù)每執(zhí)行一條tgtadm命令,就會使用這個unix socket來和tgtd通信。
當(dāng)在命令行里敲一條tgtadm命令時,通過unix socket發(fā)起請求,就會觸發(fā)epoll 的EPOLLIN事件,tgtd端accept,將連接fd加到epoll中,并注冊回調(diào)函數(shù)mtask_recv_send_handler,返回連接建立的響應(yīng)給tgtadm端,然后tgtadm命令觸發(fā)EPOLLIN事件,tgtd端調(diào)用mtask_recv_send_handler,根據(jù)不同的mode調(diào)用不同的處理函數(shù)進(jìn)行處理(這里有sys_mgmt/target_mgmt/portal_mgmt等),處理完后,將事件改為EPOLLIN|EPOLLOUT,然后發(fā)送響應(yīng)給tgtadm端。
tgtd進(jìn)程在啟動的時候就會創(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,然后當(dāng)收到EPOLLIN事件時,會調(diào)用iscsi_rx_handler進(jìn)行iscsi請求的一些解析處理操作,并調(diào)用backing store的接口進(jìn)行io的操作,操作完成后,修改事件為EPOLLLOUT,就會觸發(fā)調(diào)用到iscsi_tx_handler來發(fā)送響應(yīng)給initiator。
下面給出了iscsi_rx_handler的一些函數(shù)調(diào)用棧關(guān)系,其中涉及到與backing store中io處理接口的調(diào)用關(guān)系。2. backing store
tgt支持多種后端存儲,比如rdwr,aio,sg,rbd,sheepdog等,默認(rèn)的是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時的一些初始化操作,比如打開設(shè)備文件,創(chuàng)建處理現(xiàn)線程,注冊處理回調(diào)函數(shù)等。
bs_cmd_submit:io請求到來時就會調(diào)用該函數(shù)進(jìn)行處理。
bs_close和bs_exit就是刪除lun的時候做一些銷毀操作。
BS中支持同步和異步io兩種模式(rdwr就是同步的,aio就是異步的),下面分別介紹這兩種模式。
在同步io中,每個lun都會對應(yīng)一個請求隊列(pending_list),在bs_init時就會創(chuàng)建多個線程(目前新版本一個lun默認(rèn)16個線程)。新請求到來時,調(diào)用bs_cmd_submit將請求添加到pending_list中,多個線程共享這個pending_list,分別從pending_list中取請求來進(jìn)行處理。當(dāng)沒有請求時,這些線程就會等待在pending_list上,有新請求加入到pending_lsit后,就會喚醒等待的線程來進(jìn)行處理。
tgt使用的是linux native aio來實現(xiàn)的,使用eventfd創(chuàng)建的fd將aio上下文和epoll聯(lián)系起來。(具體可以參考aio與epoll結(jié)合起來如何使用的一些資料)。下面是一些具體的處理邏輯。
1)bs_aio_open:io_setup建立異步io上下文 ,然后afd=eventfd() ,將afd加到epoll中(回調(diào)函數(shù)bs_aio_get_completions) ,并且afd與aio的上下文關(guān)聯(lián)。
2)bs_aio_cmd_submit:IO到來時調(diào)用,先把請求加到cmd_wait_list中,然后遍歷list,確定此次能提交的io數(shù)并初始化iocb(因為限制了aio的最大處理個數(shù)為128,有些io還在處理中,當(dāng)前提交的aio個數(shù)就有限),然后使用io_submit提交一批異步io。
3)IO處理完后,會通過afd觸發(fā)EPOLLIN事件,調(diào)用回調(diào)函數(shù)bs_aio_get_completions進(jìn)行處理,先read出當(dāng)前完成的io數(shù),然后調(diào)用
io_getevents()獲取出已完成io的信息,然后對每個完成的io調(diào)用bs_aio_comlete_one做一些結(jié)束的處理(修改處理狀態(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ā)送響應(yīng)。
到此,關(guān)于“tgt程序框架知識點有哪些”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。