浅谈分布式数据库

网友投稿 727 2023-04-03

浅谈分布式数据库

浅谈分布式数据库

基本概念

​ 4) 互联网公司数据库实际软件架构是(大数据量下):又分片,又分组(如下图)

数据分片简介和问题

数据分片是按照某个维度将存放在单一数据库中的数据分散地存放至多个数据库或表中以达到提升性能瓶颈以及可用性的效果。数据分片的拆分方式分为垂直分片和水平分片

垂直分片

优点:可以一定程度上缓解数据量和访问量的压力.问题: 垂直分片往往需要对架构和设计进行调整. 这就造成无法及时响应业务要求,同时由于数据热点的问题,也往往无法彻底解决单点问题.

水平分片

优点:水平分片理论上突破了单机数据量处理的瓶颈,可以无限横向扩展.是解决单机数据量和访问量限制的终极方案.缺点:

数据库操作更繁重,数据定位繁琐.关联操作(分组,聚合,分页,排序等跨单元操作)需要特殊处理.表名称

因为数据库切分是将整体数据,切分为多份存储,这样就产生了逻辑表和真实表的概念.真实表:就是实际进行数据存储的表.逻辑表:就是原本数据单个数据库中的表.即真实表的总和.如:真实表可能分为order_0,order_1,那么逻辑表就是order表,它表示了order表未被切分时的状态.

分布式事务,跨库join(查询).分表操作,如果要动态增加表时,如果采取hash的方式就存在rehash导致的数据迁移

分片和分库分表的关系

垂直,水平分片是分布式数据库架构方案.分库,分表是实现方式,分库既可以是垂直也可以是水平切分,分表也同样可以有垂直,水平两种切分方式.

读写分离

主从数据库是解决数据库单点问题的简单方案,即根据读写操作上区分数据库职责,以降低单一数据库的访问压力.应用场景:针对于读多写少的系统,通过拆分更新操作和查询操作,来避免数据更新导致的行锁,提高整个系统的查询性能.一主多从:分散查询请求,进一步提高查询性能.存在单点问题.多主多从:提升系统吞吐量,可用性

存在问题:数据不一致.主库之间,主库和从库之间.

如:主键一致性问题.为了高可用,会进行多主部署,如果表主键采取auto_increment,且主库双向同步,a库入库数据后,与b库同步数据如果出现问题,b库入库数据后,再进行ab库数据同步就可能存在主键冲突的问题.

主从数据库数据一致性问题主从数据一致性原理:主库用于写,更新操作;从库用于数据读取操作.当主从数据库数据同步存在延迟时,就会造成主从数据库的一致性问题.主库->写->binlog->IO线程->从库延迟原因:从库读取binlog时,会串行执行sql,而主库是并行执行sql;主库故障造成未写入binlog

解决方案:1 降低从库读取压力.做法:分库,增加从库机器配置,增加从库机器(一主多从),增加服务缓存2 直连主库.会造成主存数据库失去意义.ShardingSphere在同一个线程且同一个数据库连接进行写操作时,会采取直连主库的方式,避免数据不一致的问题.

读写分离数据延迟问题

主要处理方式如下:

忽略 实际写少读多的应用,看你的业务是否允许一定程度的数据不一致.感觉像招投标这种行业,对于数据没有这么强的一致性要求.实际的技术选型总会对于准确和便捷做出一些妥协.强制读主库 对于数据实时性要求较高的根本做法还是去读主库,因为主库的数据才会没有延迟的问题.从库数据读取选择性读主 通过缓存来记录数据库,表,主键,消息有效期(主从同步时延)增加集中式缓存 数据入库时先将数据存入缓存.这个时候pc端存入数据,移动端登陆时去缓存中可以取到对应的订单数据.这种做法存在热点数据问题.

参考资料:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:一步步带你了解分布式数据库的架构演变之路!
下一篇:[分享]浅谈分布式数据库
相关文章