mongodb完全替代mysql MySQL分庫分表之后,id主鍵如何處理?
MySQL分庫分表之后,id主鍵如何處理?我將從存在的問題和如何做中回答這個問題。。沒有辦法避免這個問題,通常拆分SQL,使用多個查詢,然后使用結(jié)果分別檢查結(jié)果!我們可以使用TCC編程模型來確保兩個事
MySQL分庫分表之后,id主鍵如何處理?
我將從存在的問題和如何做中回答這個問題。。
沒有辦法避免這個問題,通常拆分SQL,使用多個查詢,然后使用結(jié)果分別檢查結(jié)果
!我們可以使用TCC編程模型來確保兩個事務可以正確提交,但這種代碼入侵方式相對較重!您還可以使用基于消息的數(shù)據(jù)一致性保證
!1. 使用多線程分別查詢多個節(jié)點,然后匯總
redis、memcache和mongodb各自的優(yōu)點是什么,怎么選擇呢?
Mongodb不應與redis/Memcache相比,因為它們的應用場景完全不同。
Mongodb是介于內(nèi)存數(shù)據(jù)庫和關(guān)系數(shù)據(jù)庫之間的數(shù)據(jù)庫。它是一個高性能、無模式的文檔數(shù)據(jù)庫。
Mongodb數(shù)據(jù)存儲在磁盤上。只有在必要時,才會通過MMAP映射到內(nèi)存,并在內(nèi)存中進行修改。修改后,操作系統(tǒng)負責刷新磁盤。
優(yōu)點:支持復雜的數(shù)據(jù)結(jié)構(gòu),能存儲海量數(shù)據(jù),能提供關(guān)系數(shù)據(jù)庫等強大的查詢功能。
Redis是一個開源的鍵值存儲系統(tǒng)。所有數(shù)據(jù)都存儲在內(nèi)存中。持久性處于RDB模式或AOF模式。只支持key、string、hash、list和set。優(yōu)點:讀寫速度非???。缺點:受內(nèi)存限制,不能存儲太多的數(shù)據(jù),不能提供強大的查詢功能,只能使用單核。
Memcache是一個高性能的分布式內(nèi)存對象緩存系統(tǒng),用于動態(tài)web應用程序以減少數(shù)據(jù)庫負載。Memcache只支持簡單的鍵值結(jié)構(gòu),但使用多核。
在爬蟲中,經(jīng)常使用redis mongodb的方式。Mongodb用來存儲被爬網(wǎng)的海量數(shù)據(jù),redis用來消除重復并保存被爬網(wǎng)的URL。