数据库分片
1、数据分片
数据库IO特别大时,将一张表的数据分片到多个数据库服务器上,降低数据库服务器压力
分片目标
分片特点
2、实现方式
2-1、硬编码实现数据分片
data:image/s3,"s3://crabby-images/e0acc/e0accf0235d26078b95c184988285caf9620d8ec" alt=""
2-2、映射表外部存储
可以建立多个映射表,用多个方式进行映射,较为灵活;
在实践中不多见,原因:
1、一次查询变成两次查询;
2、对应用程序增加复杂性,带来数据不一致性;
data:image/s3,"s3://crabby-images/ae3d9/ae3d9e5cdc40f8410a9eaec17ef673c8e131e47a" alt=""
3、分布式数据库中间件
由分布式数据库中间件,进行路由选择
原理:
1、配置路由规则;
2、
data:image/s3,"s3://crabby-images/24aeb/24aebd9156b7bffeb3e61c11f0efbc13cefc1cd7" alt=""
Cobar系统组件模型
data:image/s3,"s3://crabby-images/c011c/c011c4a61135238da94d5aa89cd7e1407fc83b04" alt=""
4、当数据库服务器增加时,应该如何处理?
先作业务分片
再对客户
5、数据库部署方案
data:image/s3,"s3://crabby-images/ab283/ab283f069473efba80587fb226a529b1fb24e6e4" alt=""
2、NoSQL
2-1、CAP原理
1、一致性Consistency
一致性是说,每次读取的数据都应该是最近写入的数据或者返回一个错误(Every read receives the most recent write or an error), 而不是过期数据,也就是数据是一致的;
操作是不保证的,但是数据一定是最新的
2、可用性Availability
不保证数据是最新的,但是操作一定是对的
data:image/s3,"s3://crabby-images/706e8/706e892976722a7b0f2fc894955fbad50eb7970a" alt=""
3、分区忍受性
data:image/s3,"s3://crabby-images/f5c18/f5c187bf4048bbf699c4191bf83a3b6c81a03d47" alt=""
4、CAP原理
当网络分区失效发生的时候,我们要么取消操作,这样数据就是一致的,但是系统却不可用;
要么我们继续写入数据,但是数据的一致性就等不到保证;
data:image/s3,"s3://crabby-images/e2274/e22743e61bbe72d5dba12eb0c8c915733ed05440" alt=""
满足分区耐受性情况下,可用性和一致性无法同时满足
两个数据库同时写,可用性降低;
2-2、CAP原理与数据一致性冲突
data:image/s3,"s3://crabby-images/300df/300dff49cacc596f953de2837a909f8e3e5bb288" alt=""
2-3、最终一致性
完全高可用的系统代价非常大;
2-4、最终一致性
data:image/s3,"s3://crabby-images/94616/946167a08eac845049e8ade021eb736e2c0b6b33" alt=""
2-4-1、最终一致性写冲突
data:image/s3,"s3://crabby-images/4a559/4a559594e2034f76f12546d95b2045ee90620875" alt=""
2-4-2、客户端冲突解决
data:image/s3,"s3://crabby-images/ebc5d/ebc5d284e0c7e95534cc557f3a1265f9e83ce438" alt=""
2-5、投票解决冲突(Cassandra)
这个是不是双写或者叫三写?同时写入多个数据源?
降低了可用性;
只有一个节点成功,写入数据失败;
data:image/s3,"s3://crabby-images/84e0f/84e0f7bf100159cee608ff6c9762a45ee3aaf301" alt=""
Cassandra分布式架构
data:image/s3,"s3://crabby-images/52d97/52d97aeeedd60b22579ba053100a2853044e9cd7" alt=""
2-6、HBase架构
HBase不需要选择HRegionServer,通过HMaster询问选择
Zookeeper选择一个Master,当Master宕机,Zookeeper重新选举;
Zookeeper解决一致性
脑裂
服务器宕机数据不会丢失
data:image/s3,"s3://crabby-images/e6220/e6220168ef330ceacf662dd3ec8ad32ccf53feb3" alt=""
可用性:一个Key只会由一个HRegionServer保证读写;
HBase可用性较差,当一个HRegionServer宕机后,宕机Server负责的Key,需要重新分配给其他Server;
data:image/s3,"s3://crabby-images/7e5ef/7e5ef7c993d9f2448bc4a57fde316e92ee76782b" alt=""
data:image/s3,"s3://crabby-images/40f90/40f90c14a437fb6a3cba2c834f508211c7e9222d" alt=""
data:image/s3,"s3://crabby-images/a1fe9/a1fe9955c11fd7ff7fe200e7798fc17889625a64" alt=""
1、doris
data:image/s3,"s3://crabby-images/fa2ad/fa2ad2a3543cc26a54e14b87883ae16cc2f305db" alt=""
版权声明: 本文为 InfoQ 作者【Arthur】的原创文章。
原文链接:【http://xie.infoq.cn/article/400f35da1ff24b27e8a68ba4d】。未经作者许可,禁止转载。
评论