高并發(fā)下uuid會重復(fù)嗎 支撐日活百萬用戶的高并發(fā)系統(tǒng),應(yīng)該如何設(shè)計其數(shù)據(jù)庫架構(gòu)? ?
支撐日活百萬用戶的高并發(fā)系統(tǒng),應(yīng)該如何設(shè)計其數(shù)據(jù)庫架構(gòu)? ?以MySQL為列:1:要支持高并發(fā)系統(tǒng),必須涉及事務(wù),所以數(shù)據(jù)庫引擎必須選擇InnoDB。InnoDB支持事務(wù),事務(wù)級別取決于業(yè)務(wù)。如果業(yè)務(wù)
支撐日活百萬用戶的高并發(fā)系統(tǒng),應(yīng)該如何設(shè)計其數(shù)據(jù)庫架構(gòu)? ?
以MySQL為列:
1:要支持高并發(fā)系統(tǒng),必須涉及事務(wù),所以數(shù)據(jù)庫引擎必須選擇InnoDB。InnoDB支持事務(wù),事務(wù)級別取決于業(yè)務(wù)。如果業(yè)務(wù)數(shù)據(jù)一致性要求非常高,事務(wù)將開啟序列化級別,這將完全隔離事務(wù),但會導(dǎo)致對鎖資源的競爭加劇。MySQL的性能在一定程度上降低了。
2:數(shù)據(jù)庫分為主數(shù)據(jù)庫和從數(shù)據(jù)庫。主數(shù)據(jù)庫負(fù)責(zé)寫入數(shù)據(jù),集群數(shù)據(jù)庫負(fù)責(zé)讀取數(shù)據(jù)。注意主從數(shù)據(jù)庫的數(shù)據(jù)一致性。
3:冷熱數(shù)據(jù)分離,美團(tuán)、饑餓部分設(shè)計采用冷熱數(shù)據(jù)分離。以訂單為例,出庫單的主要業(yè)務(wù)場景是查詢。數(shù)據(jù)查詢越向前,概率越低。這是冷數(shù)據(jù)。正在交易的訂單是熱點(diǎn)數(shù)據(jù),需要隨時查詢和更新。冷數(shù)據(jù)可以放入redis緩存。這將提高查詢效率。
4:數(shù)據(jù)表設(shè)計,充分利用索引查詢。businesssql避免返回?zé)o用的行和列,禁止使用select*query,在查詢時增加限制,并盡可能返回滿足要求的行。對于復(fù)雜的SQL,請考慮拆分SQL。拆分SQL有一個優(yōu)點(diǎn)。對于重復(fù)查詢SQL,將第二次查詢放入MySQL緩沖區(qū),避免重復(fù)磁盤操作,提高訪問性能。
5:子數(shù)據(jù)庫和子表。例如,業(yè)務(wù)數(shù)據(jù)按月份分類。在一定程度上,增加、刪除、修改和檢查的壓力將得到緩解。
希望對您有所幫助。謝謝您。
javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號?
1. 如果主題不要求ID是數(shù)字,建議使用最簡單的一個,即UUID,它包含機(jī)器代碼、時間戳、隨機(jī)數(shù)等,但UUID最終生成一個全局唯一的字符串,而不是整數(shù),并且看起來順序不對。
2. MySQL自己添加ID。它使用一個表來存儲各種業(yè)務(wù)id。每個分布式系統(tǒng)插入一個ID后,生成1000萬個本地號碼與ID拼接,然后每個系統(tǒng)得到一個ID,相當(dāng)于生成1000萬個ID,足夠長時間使用。這1000萬個ID可以預(yù)先定義,并在系統(tǒng)啟動時放入內(nèi)存。因?yàn)樗鼈冎皇荌D,所以不會占用太多內(nèi)存。MySQL可以內(nèi)置到集群中,這不會影響自增IDs的使用。
3. 與MySQL的auto-increment ID類似,redis的incr實(shí)現(xiàn)了自動增量。每個分布式系統(tǒng),比如redis,都是用incr插入一個ID,然后生成1000萬個本地號碼與ID拼接,如果每個系統(tǒng)都有一個ID,相當(dāng)于生成1000萬個ID,足夠長時間使用。這1000萬個ID可以預(yù)先定義,并在系統(tǒng)啟動時放入內(nèi)存。因?yàn)樗皇且粋€ID,所以不會占用太多內(nèi)存。Redis也可以內(nèi)置到集群中,這不會影響自增ID的使用。Twitter的雪花算法與UUID類似,包括機(jī)器碼、時間戳、隨機(jī)數(shù)等,但最終生成的是64位整數(shù),可以滿足許多分布式系統(tǒng)的要求。如果Id必須是整數(shù),建議使用snowflake而不是UUID。