日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

用uid分库,uname上的查询怎么办?

發布時間:2023/12/9 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用uid分库,uname上的查询怎么办? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

【緣起】

用戶中心是幾乎每一個公司必備的基礎服務,用戶注冊、登錄、信息查詢與修改都離不開用戶中心。

?

當數據量越來越大時,需要多用戶中心進行水平切分。最常見的水平切分方式,按照uid取模分庫:

通過uid取模,將數據分布到多個數據庫實例上去,提高服務實例個數,降低單庫數據量,以達到擴容的目的。

?

水平切分之后:

uid屬性上的查詢可以直接路由到庫,如上圖,假設訪問uid=124的數據,取模后能夠直接定位db-user1。

?

對于uname上的查詢,就不能這么幸運了:

uname上的查詢,如上圖,假設訪問uname=shenjian的數據,由于不知道數據落在哪個庫上,往往需要遍歷所有庫【掃全庫法】,當分庫數量多起來,性能會顯著降低。

?

用uid分庫,如何高效實現上的查詢,是本文將要討論的問題。

?

【索引表法】

思路:uid能直接定位到庫,uname不能直接定位到庫,如果通過uname能查詢到uid,問題解決

解決方案

1)建立一個索引表記錄uname->uid的映射關系

2)用uname來訪問時,先通過索引表查詢到uid,再定位相應的庫

3)索引表屬性較少,可以容納非常多數據,一般不需要分庫

4)如果數據量過大,可以通過uname來分庫

潛在不足:多一次數據庫查詢,性能下降一倍

?

【緩存映射法】

思路:訪問索引表性能較低,把映射關系放在緩存里性能更佳

解決方案

1)uname查詢先到cache中查詢uid,再根據uid定位數據庫

2)假設cache miss,采用掃全庫法獲取uname對應的uid,放入cache

3)uname到uid的映射關系不會變化,映射關系一旦放入緩存,不會更改,無需淘汰,緩存命中率超高

4)如果數據量過大,可以通過name進行cache水平切分

潛在不足:多一次cache查詢

?

uname生成uid

思路:不進行遠程查詢,由uname直接得到uid

解決方案

1)在用戶注冊時,設計函數uname生成uid,uid=f(uname),按uid分庫插入數據

2)用uname來訪問時,先通過函數計算出uid,即uid=f(uname)再來一遍,由uid路由到對應庫

潛在不足:該函數設計需要非常講究技巧,有uid生成沖突風險

?

uname基因融入uid

思路:不能用uname生成uid,可以從uname抽取“基因”,融入uid中

假設分8庫,采用uid%8路由,潛臺詞是,uid的最后3個bit決定這條數據落在哪個庫上,這3個bit就是所謂的“基因”。

?

解決方案

1)在用戶注冊時,設計函數uname生成3bit基因,uname_gene=f(uname),如上圖粉色部分

2)同時,生成61bit的全局唯一id,作為用戶的標識,如上圖綠色部分

3)接著把3bit的uname_gene也作為uid的一部分,如上圖屎黃色部分

4)生成64bit的uid,由id和uname_gene拼裝而成,并按照uid分庫插入數據

5)用uname來訪問時,先通過函數由uname再次復原3bit基因,uname_gene=f(uname),通過uname_gene%8直接定位到庫

?

【總結】

業務場景:用戶中心,數據量大,通過uid分庫后,通過uname路由不到庫

?

解決方案

1)掃全庫法:遍歷所有庫

2)索引表法:數據庫中記錄uname->uid的映射關系

3)緩存映射法:緩存中記錄uname->uid的映射關系

4)uname生成uid

5)uname基因融入uid

轉載于:https://my.oschina.net/architectliuyuanyuan/blog/1590330

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的用uid分库,uname上的查询怎么办?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。