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

云MongoDB優化讓LBS服務性能提升十倍

企業動態 MongoDB
隨著國內服務共享化的熱潮普及,共享單車,共享雨傘,共享充電寶等各種服務如雨后春筍,隨之而來的LBS服務定位問題成為了后端服務的一個挑戰。MongoDB對LBS查詢的支持較為友好,也是各大LBS服務商的首選數據庫。

隨著國內服務共享化的熱潮普及,共享單車,共享雨傘,共享充電寶等各種服務如雨后春筍,隨之而來的LBS服務定位問題成為了后端服務的一個挑戰。MongoDB對LBS查詢的支持較為友好,也是各大LBS服務商的首選數據庫。騰訊云MongoDB團隊在運營中發現,原生MongoDB在LBS服務場景下有較大的性能瓶頸,經騰訊云團隊專業的定位分析與優化后,云MongoDB在LBS服務的綜合性能上,有10倍以上的提升。

騰訊云MongoDB提供的優異綜合性能,為國內各大LBS服務商,例如摩拜單車等,提供了強有力的保障。

LBS業務特點

以共享單車服務為例,LBS業務具有2個特點,分別是時間周期性和坐標分布不均勻。

一.時間周期性

高峰期與低谷期的QPS量相差明顯,并且高峰期和低峰期的時間點相對固定。

二.坐標分布不均勻

坐地鐵的上班族,如果留意可能會發現,在上班早高峰時,地鐵周圍擺滿了共享單車,而下班 時段,地鐵周圍的共享單車數量非常少。如下圖,經緯度(121,31.44)附近集中了99%以上 的坐標。此外,一些特殊事件也會造成點的分布不均勻,例如深圳灣公園在特殊家假日涌入大量的客戶,同時這個地域也會投放大量的單車。部分地域單車量非常集中,而其他地域就非常稀疏。

MongoDB的LBS服務原理

MongoDB中使用2d_index 或2d_sphere_index來創建地理位置索引(geoIndex),兩者差別不大,下面我們以2d_index為例來介紹。

一.2D索引的創建與使用

  1. db.coll.createIndex({"lag":"2d"}, {"bits":int})) 
  2. 通過上述命令來創建一個2d索引,索引的精度通過bits來指定,bits越大,索引的精度就越高。更大的bits帶來的插入的overhead可以忽略不計 
  3. db.runCommand({ 
  4. geoNear: tableName, 
  5. maxDistance: 0.0001567855942887398, 
  6. distanceMultiplier: 6378137.0, 
  7. num: 30, 
  8. near: [ 113.8679388183982, 22.58905429302385 ], 
  9. spherical: true|false}) 

通過上述命令來查詢一個索引,其中spherical:true|false 表示應該如何理解創建的2d索引,false表示將索引理解為平面2d索引,true表示將索引理解為球面經緯度索引。這一點比較有意思,一個2d索引可以表達兩種含義,而不同的含義是在查詢時被理解的,而不是在索引創建時。

二.2D索引的理論

MongoDB 使用GeoHash的技術來構建2d索引(見wiki geohash 文字鏈https://en.wikipedia.org/wiki/Geohash )。MongoDB使用平面四叉樹劃分的方式來生成GeoHashId,每條記錄有一個GeoHashId,通過GeoHashId->RecordId的索引映射方式存儲在Btree中

很顯然的,一個2bits的精度能把平面分為4個grid,一個4bits的精度能把平面分為16個grid。

2d索引的默認精度是長寬各為26,索引把地球分為(2^26)(2^26)塊,每一塊的邊長估算為2PI6371000/(1<<26) = 0.57 米

mongodb的官網上說的60cm的精度就是這么估算出來的

By default, a 2d index on legacy coordinate pairs uses 26 bits of precision, which isroughly equivalent to 2 feet or 60 centimeters of precision using the default range of-180 to 180

三.2D索引在Mongodb中的存儲

上面我們講到Mongodb使用平面四叉樹的方式計算Geohash。事實上,平面四叉樹僅存在于運算的過程中,在實際存儲中并不會被使用到。

插入

對于一個經緯度坐標[x,y],MongoDb計算出該坐標在2d平面內的grid編號,該編號為是一個52bit的int64類型,該類型被用作btree的key,因此實際數據是按照 {GeoHashId->RecordValue}的方式被插入到btree中的。

查詢

對于geo2D索引的查詢,常用的有geoNear和geoWithin兩種。geoNear查找距離某個點最近的N個點的坐標并返回,該需求可以說是構成了LBS服務的基礎(陌陌,滴滴,摩拜),geoWithin是查詢一個多邊形內的所有點并返回。我們著重介紹使用最廣泛的geoNear查詢。

geoNear的查詢過程,查詢語句如下

  1. db.runCommand( 
  2. geoNear: "places", //table Name 
  3. near: [ -73.9667, 40.78 ] , // central point 
  4. spherical: true, // treat the index as a spherical index 
  5. query: { category: "public" } // filters 
  6. maxDistance: 0.0001531 // distance in about one kilometer 

 

geoNear可以理解為一個從起始點開始的不斷向外擴散的環形搜索過程。如下圖所示:

由于圓自身的性質,外環的任意點到圓心的距離一定大于內環任意點到圓心的距離,所以以圓

環進行擴張迭代的好處是:

1)減少需要排序比較的點的個數

2)能夠盡早發現滿足條件的點從而返回,避免不必要的搜索

MongoDB在實現的細節中,如果內環搜索到的點數過少,圓環每次擴張的步長會倍增

MongoDB LBS服務遇到的問題

部分大客戶在使用MongoDB的geoNear功能查找附近的對象時,經常會發生慢查詢較多的問題,早高峰壓力是低谷時段的10-20倍,坐標不均勻的情況慢查詢嚴重,瀕臨雪崩。初步分析發現,這些查詢掃描了過多的點集。

如下圖,查找500米范圍內,距離最近的10條記錄,花費了500ms,掃描了24000+的記錄。類似的慢查詢占據了高峰期5%左右的查詢量

測試環境復現與定位

排查數據庫的性能問題,主要從鎖等待,IO等待,CPU消耗三封面分析。上面的截圖掃描了過多的記錄,直覺上是CPU或者IO消耗性的瓶頸。為了嚴謹起見,我們在測試環境復現后,發現慢日志中無明顯的timeAcquiringMicroseconds項排除了MongoDB執行層面的鎖競爭問題,并選用較大內存的機器使得數據常駐內存,發現上述用例依舊需要200ms以上的執行時間。10核的CPU資源針對截圖中的case,只能支持50QPS。

為何掃描集如此大

上面我們說過,MongoDB搜索距離最近的點的過程是一個環形擴張的過程,如果內環滿足條件的點不夠多,每次的擴張半徑都會倍增。因此在遇到內環點稀少,外環有密集點的場景時,容易陷入BadCase。如下圖,我們希望找到離中心點距離最近的三個點。由于圓環擴張太快,外環做了很多的無用掃描與排序。

這樣的用例很符合實際場景,早高峰車輛聚集在地鐵周圍,你從家出發一路向地鐵,邊走邊找,共享單車軟件上動態搜索距你最近的10輛車,附近只有三兩輛,于是擴大搜索半徑到地鐵周圍,將地鐵周圍的所有幾千輛車都掃描計算一遍,返回距離你最近的其余的七八輛

問題的解決

問題我們已經知道了,我們對此的優化方式是控制每一圈的搜索量,為此我們為geoNear命令增加了兩個參數,將其傳入NearStage中。hintCorrectNum可以控制結果品質的下限,返回的前N個一定是最靠近中心點的N個點。hintScan用以控制掃描集的大小的上限。

hintScan: 已經掃描的點集大小大于hintScan后,做模糊處理。

hintCorrectNum:已經返回的結果數大于hintCorrectNum后,做模糊處理。

該優化本質上是通過犧牲品質來盡快返回結果。對于國內大部分LBS服務來說,完全的嚴格最近并不是必要的。且可以通過控制參數獲得嚴格最近的效果。在搜索過程中,密集的點落到一個環內,本身距離相差也不會不大。該優化在上線后,將部分大客戶的MongoDB性能上限從單機1000QPS提升了10倍到10000QPS以上。

和Redis3.2的對比

Redis3.2也加入了地理位置查詢的功能,我們也將開源Redis和云數據庫MongoDB進行對比。

Redis使用方式:GEORADIUS appname 120.993965 31.449034 500 m count 30 asc。在密集數據集場景下,使用騰訊云MongoDB和開源的Redis進行了性能對比。下圖是在密集數據集上,在24核CPU機器上,MongoDB單實例與Redis單實例的測試對比。需要注意的是Redis本身是單線程的內存緩存數據庫。MongoDB是多線程的高可用持久化的數據庫,兩者的使用場景有較大不同。

總結

MongoDB原生的geoNear接口是國內各大LBS應用的主流選擇。原生MongoDB在點集稠密的情況下,geoNear接口效率會急劇下降,單機甚至不到1000QPS。騰訊云MongoDB團隊對此進行了持續的優化,在不影響效果的前提下,geoNear的效率有10倍以上的提升,為我們的客戶如摩拜提供了強力的支持,同時相比Redis3.2也有較大的性能優勢。

原文鏈接:https://cloud.tencent.com/community/article/723875

【本文是51CTO專欄作者“騰訊云技術社區”的原創稿件,轉載請通過51CTO聯系原作者獲取授權】

戳這里,看該作者更多好文

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2025-10-10 05:56:11

2025-05-26 00:02:00

TypeScriptGo 語言前端

2023-09-07 11:29:36

API開發

2021-11-18 10:05:35

Java優化QPS

2024-06-27 11:22:34

2023-06-13 13:52:00

Java 7線程池

2024-12-06 06:20:00

代碼枚舉

2025-05-26 04:00:00

2024-08-01 08:06:11

虛擬線程性能

2025-03-13 11:59:00

2025-07-22 13:17:30

2021-09-13 10:25:35

開發技能代碼

2023-03-08 18:43:50

GPU模型隔離

2011-07-19 10:46:49

Windows 7優化

2022-10-27 07:09:34

DjangoAPIRedis

2012-12-24 09:55:15

JavaJava WebJava優化

2025-08-12 07:46:29

2025-08-01 07:36:26

2019-03-27 13:45:44

MySQL優化技巧數據庫

2017-12-06 08:06:47

IBMGPU機器學習
點贊
收藏

51CTO技術棧公眾號

区一区二区三区中文字幕| 久久电影一区二区| 337p粉嫩大胆噜噜噜鲁| 你懂的在线播放| 免费一级欧美片在线观看| 亚洲欧美国产精品久久久久久久| 天堂在线资源视频| 污污片在线免费视频| 97久久久精品综合88久久| 国产精品极品美女粉嫩高清在线| www.99re7| 日本三级久久| 5566中文字幕一区二区电影| 无码人妻少妇伦在线电影| 精品推荐蜜桃传媒| 韩国av一区二区三区| 91精品国产91久久久| 北条麻妃在线观看视频| 日韩欧美影院| 日韩一区二区视频在线观看| 免费日韩视频在线观看| 日本动漫同人动漫在线观看| 国产日韩av一区| 国产日韩精品久久| 国产精品久久婷婷| 丝袜美腿亚洲综合| 久久久久久久国产| 三级在线观看免费大全| 国产精品美女久久久久久不卡| 91精品国产品国语在线不卡| 激情内射人妻1区2区3区 | 成午夜精品一区二区三区软件| 欧美性xxxxxxxxx| 99在线免费视频观看| 麻豆av免费在线观看| 国产日本亚洲高清| 久久伦理网站| 欧美熟妇交换久久久久久分类| 六月婷婷色综合| 日本一区二区三区在线播放| 国产小视频在线观看免费| 五月婷婷亚洲| 日韩一级黄色av| 亚洲一二三四视频| 欧美日韩伦理| 亚洲天堂男人天堂女人天堂| av鲁丝一区鲁丝二区鲁丝三区| 久久久久久久久久久久电影| 欧美日韩一区二区三区不卡| 国产嫩草在线观看| 日韩网站中文字幕| 91福利在线免费观看| 色欲av无码一区二区人妻| 美女露胸视频在线观看| 五月激情六月综合| 尤物av无码色av无码| 69av成人| 欧美色xxxx| 欧美日韩激情视频在线观看| 理论片午夜视频在线观看| 香蕉成人伊视频在线观看| 欧美激情视频免费看| www成人免费观看| 午夜精品福利一区二区三区av | 手机免费看av| 精品99久久| 在线观看久久久久久| 91精品久久久久久久久久久久| 精品欧美激情在线观看| 中文字幕综合一区| 麻豆明星ai换脸视频| 欧美日韩一区二区三区四区在线观看| 九九久久久久久久久激情| 国产中文字字幕乱码无限| 国产精品videosex性欧美| 亚洲天堂开心观看| 久久嫩草捆绑紧缚| 国产一区久久| 午夜精品www| 一本一道无码中文字幕精品热| 玖玖在线精品| 国产欧美日韩免费| jizz国产视频| 26uuu国产在线精品一区二区| 日本一区视频在线| 国产在线一区二区视频| 亚洲成人一区在线| 一区二区在线播放视频| 国产精品99久久免费| 精品电影一区二区| 久久久久无码精品国产sm果冻| 99久久.com| 韩国三级电影久久久久久| 手机av免费观看| 国产一区二区三区在线观看免费视频| 国产二区不卡| 国产中文在线| 一区二区三区丝袜| 91蝌蚪视频在线观看| 欧美日韩午夜电影网| 精品亚洲一区二区三区在线观看 | 人妻少妇精品无码专区| 国产日本欧美一区二区| 亚洲精品少妇一区二区| 日本不卡一二三| 日韩欧美一卡二卡| 国产1区2区在线观看| 国一区二区在线观看| 国产精品视频不卡| 视频国产在线观看| 国产精品视频在线看| 精品少妇在线视频| 成人污版视频| 这里只有精品在线播放| 日韩精品一区三区| 国产在线精品一区二区夜色| 日本一区二区高清视频| 久久香蕉av| 欧美日本在线播放| 国产肥白大熟妇bbbb视频| 韩日在线一区| 91久久久亚洲精品| 91福利在线视频| 黑人精品xxx一区一二区| 久久久久久久久久毛片| 欧美丝袜激情| 日韩av123| 无码精品人妻一区二区| 亚洲国产aⅴ成人精品无吗| 日本国产一级片| 国产日产精品一区二区三区四区的观看方式 | 在线观看麻豆| 91成人国产精品| aaaaaav| 欧美视频亚洲视频| 91九色国产在线| 又爽又大又黄a级毛片在线视频| 色综合天天综合网天天狠天天| 精品1卡二卡三卡四卡老狼| 欧美.www| 91精品国产高清久久久久久91裸体| a√在线中文网新版址在线| 在线观看日韩毛片| a天堂中文字幕| 噜噜噜躁狠狠躁狠狠精品视频| 国产综合18久久久久久| xxxx在线视频| 亚洲电影中文字幕| 久久久久久久99| 不卡一卡二卡三乱码免费网站| 女人色极品影院| 亚洲专区**| 欧美精品第一页在线播放| www.天天干.com| 亚洲在线视频网站| 丰满人妻一区二区三区免费视频棣| 亚洲欧美文学| 国产一区在线免费| 香蕉伊大人中文在线观看| 日韩成人av网| 国产女主播喷水视频在线观看 | 久久久久久久久久久一区| 91桃色在线观看| 亚洲精品美女在线观看播放| 成人午夜淫片100集| 久久久久久久久一| 欧美日韩在线观看不卡| 91精品精品| 风间由美久久久| 日本三级一区| 中文字幕精品www乱入免费视频| 在线播放国产一区| 亚洲精品免费视频| 亚洲精品理论片| 日本欧美韩国一区三区| 国产精品久久成人免费观看| 香蕉免费一区二区三区在线观看| 欧美激情奇米色| 你懂得网站在线| 在线播放欧美女士性生活| 久久国产免费观看| 久久综合久久鬼色| 视频在线观看免费高清| 午夜久久tv| 免费在线观看91| 中文字幕综合| 97在线观看视频| 69xxxx欧美| 精品国产三级a在线观看| 日本a级c片免费看三区| 亚洲视频一区在线| 天堂久久久久久| 久久99精品国产| 日韩免费视频播放| 外国成人免费视频| 久久免费视频1| 免费精品一区| 国产999精品久久久| а天堂中文在线官网| 亚洲欧美精品一区| 99国产在线播放| 色综合天天天天做夜夜夜夜做| 大地资源高清在线视频观看| 91视频免费播放| 日本黄色一级网站| 日本在线观看不卡视频| 蜜臀av无码一区二区三区| 日韩精品诱惑一区?区三区| 国产精品制服诱惑| 亚洲电影二区| 日本久久精品视频| 91九色在线看| 久久在线视频在线| www.久久热.com| 亚洲精品久久7777777| 精品人妻午夜一区二区三区四区| 色婷婷久久综合| 黄色一级片免费看| 曰韩精品一区二区| 特级西西人体高清大胆| 2020日本不卡一区二区视频| 91精品人妻一区二区三区蜜桃2| 美女一区二区三区| 老司机午夜av| 麻豆成人精品| 日日碰狠狠添天天爽超碰97| 一区二区不卡| 欧美亚洲视频一区| 全球成人免费直播| 日韩成人在线资源| 欧美激情在线精品一区二区三区| 国产精品区一区二区三含羞草| 国产一区二区三区免费在线 | 91亚洲精品久久久蜜桃| 国产精品日日摸夜夜爽| 国产激情一区二区三区| 污视频网址在线观看| 毛片基地黄久久久久久天堂| 天堂av在线网站| 日韩电影一区二区三区| 成年人视频在线免费| 久久福利毛片| 国产性xxxx18免费观看视频| 99这里有精品| 久久久999视频| 亚洲综合国产| 黄色一级一级片| 老司机精品导航| 男人插女人下面免费视频| 天堂资源在线中文精品| 精品视频一区二区在线| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲免费二区| 日韩欧美视频免费在线观看| 99免费精品| 欧美日韩中文字幕在线播放| 韩国一区二区三区在线观看| 日韩av新片网| 亚洲欧美久久久| 日韩欧美黄色大片| 久久国产精品72免费观看| 污视频网址在线观看| 国产激情偷乱视频一区二区三区| 少妇丰满尤物大尺度写真| 岛国精品在线观看| 右手影院亚洲欧美| 日本一区免费视频| 91精品一区二区三区蜜桃| 亚洲综合免费观看高清完整版在线| 久久无码精品丰满人妻| 欧美日韩国产影院| 18国产免费视频| 日韩欧美一级特黄在线播放| 色一情一乱一乱一区91av| 亚洲男人天堂古典| 免费不卡视频| 国外成人在线视频| 免费污视频在线一区| 91系列在线播放| 欧美日韩另类图片| 亚洲欧美日韩国产成人综合一二三区| 天天色综合色| 加勒比成人在线| 日韩电影在线观看一区| xxxxwww一片| 久久精品一区八戒影视| 手机在线免费看片| 日韩欧美中文在线| 国产特级黄色片| 亚洲男女性事视频| 国产婷婷视频在线| 欧美自拍视频在线| 久久视频社区| 日本精品一区二区| 激情成人亚洲| 天天影视综合色| 成人av电影在线| а天堂中文在线资源| 精品免费在线观看| 国产乱码精品一区二三区蜜臂 | 午夜伦欧美伦电影理论片| 黄色av一区二区| 精品88久久久久88久久久| 国产香蕉在线| 韩国福利视频一区| 久久视频免费| 亚洲欧美成人一区| 欧美专区一区二区三区| 日韩av影视大全| 久久嫩草精品久久久精品| 免费无码毛片一区二区app| 欧美午夜精品理论片a级按摩| 免费观看黄一级视频| 日韩视频免费看| 日本精品裸体写真集在线观看| 成人资源av| 亚洲网色网站| 免费涩涩18网站入口| www成人在线观看| 国产在线视频99| 日韩一级片网站| 毛片免费不卡| 国产精品天天狠天天看| 九一国产精品| 91猫先生在线| av在线不卡观看免费观看| 欧美片一区二区| 在线综合视频播放| 尤物在线视频| 国产精品三级美女白浆呻吟| 国产麻豆精品久久| 免费日韩中文字幕| 91香蕉视频污在线| 日韩美女视频网站| 亚洲电影av在线| 国产又色又爽又黄刺激在线视频| 成人激情黄色网| 天天久久综合| 超碰在线免费av| 亚洲免费av在线| 国内精品久久久久久久久久久| 久久伊人91精品综合网站| 在线观看欧美| 中文字幕在线乱| 国产精品综合av一区二区国产馆| 久草手机视频在线观看| 欧美精品成人一区二区三区四区| www日韩tube| 国产精品你懂得| 欧美aaaa视频| 国产在线视频三区| 一区二区三区不卡视频| 亚洲精品.www| 久久久久久亚洲精品中文字幕| 4438全国亚洲精品观看视频| 丁香六月激情婷婷| 99精品欧美一区二区三区小说 | 欧美日韩精品欧美日韩精品| 在线免费观看黄色av| 91九色国产社区在线观看| 午夜视频一区| 黄色网址在线视频| 色欲综合视频天天天| av在线之家电影网站| 成人久久精品视频| 欧美视频网站| wwwwxxxx国产| 欧美日韩成人一区二区| 羞羞网站在线看| 蜜桃传媒视频麻豆第一区免费观看| 老司机免费视频久久| 日本视频在线免费| 欧美r级在线观看| 亚洲永久av| 在线视频91| www.成人网.com| 亚洲精品毛片一区二区三区| www.国产精品一二区| 成人免费直播在线| 韩国一区二区av| 亚洲欧美在线aaa| 亚州男人的天堂| 国产美女久久精品| 亚洲全部视频| 后入内射无码人妻一区| 精品国产凹凸成av人网站| 免费电影日韩网站| 麻豆视频传媒入口| 久久欧美一区二区| 99在线观看精品视频| 欧美一级淫片aaaaaaa视频| 欧美国产美女| 人体私拍套图hdxxxx| 欧美日韩国产高清一区二区三区 | 大色综合视频网站在线播放| 国产黄色一区二区三区| 色老汉一区二区三区| 青春草免费在线视频| 天堂av一区二区| 99精品欧美一区二区三区综合在线|