MongoDB中怎么處理Mongos請求-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關MongoDB中怎么處理Mongos 請求,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都創(chuàng)新互聯(lián)成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目網(wǎng)站設計制作、做網(wǎng)站網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元新榮做網(wǎng)站,已為上家服務,為新榮各地企業(yè)和個人服務,聯(lián)系電話:18980820575

TransportLayer接收到新連接后,會創(chuàng)建專門的conn線程負責處理該連接的后續(xù)所有請求,具體邏輯在ServiceEntryPointMongos類的_sessionloop函數(shù)中,根據(jù)請求的類型循環(huán)“收包,處理,回響應”三個步驟,總結狀態(tài)機轉換關系如下:

MongoDB中怎么處理Mongos 請求

具體到Process業(yè)務處理里面,會進一步區(qū)分消息類型并走不同處理邏輯,主要分為:查詢類(queryop/getmore), 更新類(insert/update/delete),killcursors,以及其他ClientCommand這幾種類型。

這幾類命令的前半段處理流程基本類似,包括鑒權,語法判斷,根據(jù)分區(qū)視圖查找本次操作涉及哪些shardserver,以及錯誤重試機制。后半段則和具體業(yè)務邏輯相關,存在較大差異。

查詢請求處理邏輯

MongoDB中怎么處理Mongos 請求

因為是Sharding集群模式下的查詢,根據(jù)查詢條件的不同,可能會涉及到多個Shard Server的數(shù)據(jù),根據(jù)分區(qū)視圖確認涉及的Shard Server后,針對每個ShardServer生成一個查詢任務交由TaskExecutorPool執(zhí)行。TaskExecutorPool負責維護mongos到ShardServer的長連接,并包含一個network線程池負責執(zhí)行和ShardServer的網(wǎng)絡交互。

Conn線程將查詢任務交由TaskExecutorPool任務隊列后,會wait到信號量上阻塞等待,TaskExecutorPool里的network線程完成查詢請求后,喚醒Conn線程進一步處理查詢結果。

Mongos為每一個Shard Server維護一個查詢結果緩存隊列,并按照Merge、Skip、Limit、RemoveSortKey的順序對查詢結果進行逐級處理后返回。其中Merge操作負責合并來自多個Shard Server的查詢結果,根據(jù)查詢條件是否要求排序有不同的處理邏輯:

  • 需要排序:根據(jù)SortKey在多個隊列中找排最前面的,保證全局有序返回,緩存結果處理完了就觸發(fā)到對應ShardServer查詢數(shù)據(jù);

  • 不需要排序:一個Shard Server查詢結果返回完了再返回下一個ShardServer的查詢結果;

Mongos還會為每次查詢創(chuàng)建一個ClusterCursor,并維護和每個遠程Shard Server游標的對應關系,用于后續(xù)getmore操作進一步獲取數(shù)據(jù)。

以上就是MongoDB中怎么處理Mongos 請求,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)-成都網(wǎng)站建設公司行業(yè)資訊頻道。

網(wǎng)站題目:MongoDB中怎么處理Mongos請求-創(chuàng)新互聯(lián)
標題URL:http://muchs.cn/article40/hedho.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、ChatGPT、響應式網(wǎng)站、軟件開發(fā)、品牌網(wǎng)站制作、服務器托管

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設計