亚洲乱色熟女一区二区三区丝袜,天堂√中文最新版在线,亚洲精品乱码久久久久久蜜桃图片,香蕉久久久久久av成人,欧美丰满熟妇bbb久久久

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

6大分庫(kù)分表中間件ShardingSphere、TDDL、DRDS、MyCAT、Atlas、Vitess詳解(圖文全面總結(jié))

admin
2025年6月28日 21:52 本文熱度 121

分庫(kù)分表是大型架構(gòu)的必備技能,也是大廠經(jīng)??疾斓闹攸c(diǎn)對(duì)象,下面我就全面來(lái)詳解分庫(kù)分表中間件@mikechen


最新mikechen原創(chuàng)超30萬(wàn)字《阿里架構(gòu)師進(jìn)階專題合集》和《大廠最全面試題及答案合集》,請(qǐng)關(guān)注本公眾號(hào)【mikechen的互聯(lián)網(wǎng)架構(gòu)】,后臺(tái)回復(fù):合集,即可領(lǐng)取。


分庫(kù)分表

分庫(kù)分表:是數(shù)據(jù)庫(kù)水平擴(kuò)展的一種常見(jiàn)策略,用于處理大規(guī)模數(shù)據(jù)、和高并發(fā)請(qǐng)求。

如下圖所示:

分庫(kù)分表,這里分為兩個(gè)方面,包含:分庫(kù)、和分表兩種策略。

1、分庫(kù)

分庫(kù):就是將數(shù)據(jù)水平分散到多個(gè)數(shù)據(jù)庫(kù)實(shí)例中,每個(gè)數(shù)據(jù)庫(kù)實(shí)例可以部署在不同的服務(wù)器上,從而減輕單個(gè)數(shù)據(jù)庫(kù)的壓力。

還是舉一個(gè)例子,比如:數(shù)據(jù)按照某個(gè)字段的值范圍,分布到不同的庫(kù)中。

例如:用戶ID為1-10000的數(shù)據(jù)存儲(chǔ)在庫(kù)A,10001-20000的數(shù)據(jù)存儲(chǔ)在庫(kù)B,這就是分庫(kù)。

2、分表

分表:就是在單個(gè)數(shù)據(jù)庫(kù)實(shí)例內(nèi),將數(shù)據(jù)水平分散到多個(gè)表中,從而減輕單表的壓力。

還是舉一個(gè)例子,比如:根據(jù)某個(gè)字段的值范圍分表。

例如:用戶ID為1-10000的數(shù)據(jù)存儲(chǔ)在表user_1,10001-20000的數(shù)據(jù)存儲(chǔ)在表user_2,這就是分表。

總之,分庫(kù)分表是數(shù)據(jù)庫(kù)擴(kuò)展中常用的策略,目的是提高系統(tǒng)的并發(fā)處理能力、和數(shù)據(jù)存儲(chǔ)能力。


分庫(kù)分表中間件

在了解完分庫(kù)分表后,我們一起來(lái)看看目前市場(chǎng)主流的分庫(kù)分表中間件有哪些呢?let's go!

1.ShardingSphere

ShardingSphere 是一個(gè)開(kāi)源的分布式數(shù)據(jù)庫(kù)中間件解決方案,支持:分庫(kù)分表、讀寫(xiě)分離、分布式事務(wù)、數(shù)據(jù)加密......等多種功能。

ShardingSphere 通過(guò)統(tǒng)一的接口、和高性能的實(shí)現(xiàn),為開(kāi)發(fā)者提供了透明的分庫(kù)分表支持,適用于Java等應(yīng)用。

如下圖所示:

主要包括三個(gè)核心組件:

  • Sharding-JDBC:適用于 Java 應(yīng)用程序,提供 JDBC 層的分庫(kù)分表支持;

  • Sharding-Proxy:基于 MySQL 協(xié)議的代理層,支持多語(yǔ)言應(yīng)用,客戶端無(wú)需修改代碼,即可實(shí)現(xiàn)分庫(kù)分表;

  • Sharding-Sidecar :適用于 Kubernetes 環(huán)境下的微服務(wù)架構(gòu),提供與:Sharding-JDBC 類似的功能。

ShardingSphere 適用于各種需要分布式數(shù)據(jù)庫(kù)管理的場(chǎng)景,比如:電商、社交網(wǎng)絡(luò).....等需要處理大規(guī)模數(shù)據(jù),和高并發(fā)請(qǐng)求的場(chǎng)景。

2.TDDL

TDDL,全稱是Taobao Distributed Data Layer,就是:淘寶分布式數(shù)據(jù)層。

TDDL是阿里巴巴集團(tuán)內(nèi)部開(kāi)發(fā)的一款分布式數(shù)據(jù)庫(kù)中間件,設(shè)計(jì)目標(biāo)是:解決在電商業(yè)務(wù)中遇到的大規(guī)模數(shù)據(jù)、和高并發(fā)請(qǐng)求問(wèn)題。

3.DRDS

阿里的TDDL,后續(xù)升級(jí)為:DRDS,全稱是“Distributed Relational Database Service”,是一款:分布式關(guān)系型數(shù)據(jù)庫(kù)服務(wù)。

DRDS整體架構(gòu),如下圖所示:

DRDS支持:分庫(kù)分表、讀寫(xiě)分離、和分布式事務(wù)...等技術(shù)。

DRDS廣泛應(yīng)用于數(shù)據(jù)量大的場(chǎng)景,比如:電商、金融、游戲...等領(lǐng)域。

4.MyCAT

MyCAT 是基于阿里巴巴的 Cobar 項(xiàng)目開(kāi)發(fā)的,是一個(gè)增強(qiáng)版的數(shù)據(jù)庫(kù)中間件,支持多種數(shù)據(jù)庫(kù)(如:MySQL、PostgreSQL...)等。

整體架構(gòu),如下圖所示:

MyCAT 支持將數(shù)據(jù)分散到多個(gè)數(shù)據(jù)庫(kù)實(shí)例、和多個(gè)表中,通過(guò)靈活的分片規(guī)則實(shí)現(xiàn)水平擴(kuò)展。

比如:

  • 范圍分片:根據(jù)某個(gè)字段的值范圍進(jìn)行分片;

  • 哈希分片:對(duì)某個(gè)字段進(jìn)行哈希計(jì)算,然后按哈希值取模分片;

  • 日期分片:根據(jù)日期字段進(jìn)行分片,例如:按月、或按年分片;

5.Atlas

Atlas 是由360 公司開(kāi)發(fā)的一款開(kāi)源 MySQL 數(shù)據(jù)庫(kù)中間件,可以實(shí)現(xiàn) MySQL 數(shù)據(jù)庫(kù)的水平擴(kuò)展、和高可用性。

Atlas 支持分庫(kù)分表,以及還支持讀寫(xiě)分離,將寫(xiě)請(qǐng)求發(fā)送到主庫(kù),讀請(qǐng)求發(fā)送到從庫(kù),從而提升系統(tǒng)的讀寫(xiě)性能和可用性。

6.Vitess

Vitess 是一個(gè)開(kāi)源的分布式數(shù)據(jù)庫(kù)中間件系統(tǒng),最初由 YouTube 開(kāi)發(fā),用于解決其在大規(guī)模 MySQL 集群中的擴(kuò)展性問(wèn)題。

Vitess 通過(guò)分庫(kù)分表技術(shù),將數(shù)據(jù)分散存儲(chǔ)到多個(gè) MySQL 實(shí)例中,從而提升數(shù)據(jù)庫(kù)的存儲(chǔ)能力、和并發(fā)處理能力。


閱讀原文:原文鏈接


該文章在 2025/7/1 23:55:43 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved