1.2、分布式架构设计

1、SOA和微服务

SOA 各模块间相互调用,ESB来隔离各模块,各模块都走ESB。
特点:1.有序。2.复用。3.高效。

微服务架构:业务需要彻底的组件化和服务化
特点:1.组件化。2.按业务能力划分服务和开发团队。3.去中心化。4.基础设施的自动化。

差异:1、微服务没有强调ESB,而是到各个模块去组件化。
          2、SOA注重的系统集成,微服务是完全独立完全分离。

2、领域驱动设计及业务驱动划分

3、分布式架构的基本理论CAP、BASE以及应用

a、分布式一致性的问题

数据一致性就是指在对一个副本数据进行更新的时候,必 须确保也能够更新其他的 副本,否则不同副本之间的数据 将不一致



mpaas 服务架构图 sba服务化架构_mpaas 服务架构图

     

那么如何去解决这个问题?按照正常的思路,我们可能会 想,既然是因为网络延迟导致的问题,那么我们可以把同 步动作进行阻塞,用户 2 在查询的时候必须要等到数据同 步完成以后再来做。但是这个方案带来的问题是性能会收 到非常大的影响。

所以我们没有办法找到一种能够满足数据一致性、 又不影响系统运行的性能的方案。

强一致性(保证数据一致性,但是会影响系统的性能。)、弱一致性(系统的性能很好,保证请求后有成功或失败返回,jin尽可能的保证某个时间内数据的一致性。)最终一致性(最终一致性是弱一致性的一个特例,系统 会保证在一定时间内,能够达到一个数据一致的状态。是弱一致性 中非常推崇的一种一致性模型,也是业界在大型分布式系 统的数据一致性上比较用的多的模型 )

b、CAP

一致性(Consistency)、可用性(Availability)、分区容错性(Partition-toleranc)

这三个基本需求,最多只能同时满足其中两项_(CP/AP)_

CAP并不是一个普适性原理和指导思想,它仅 适用于原子读写的NoSql场景中,并不适用于数据库系统

c、BASE

1、基本可用(搜索有1s变成2s。降级页面(当前访问量过多))

2、软状态 (状态机) 待支付、交易处理中、交易成功、交易失败

3、数据最终一致性 (基于MQ)

核心思想:即使无法做到强一致性,但每个 应用都可以根据自身业务特点,采用适当的方式来使系统 达到最终一致

4、什么是分布式架构下的高可用设计

1.避免单点故障

a、负载金恒技术(failover选址/硬件负载/软件负载/去中心化的软件负载(gossip(redis-cluster)))

b、热备 (linux HA)

c、多机房(同城灾备、异地灾备)

2、应用的高可用性

a、故障监控(系统监控(cpu、内存)/链路监控/日志监控)自动预警

b、应用的容错设计、(服务降流、限流) 自我保护能力

c、数据量 (数据分片、读写分离)

5、分布式架构下的可伸缩设计

垂直伸缩 (提升硬件能力)

水平伸缩 (增加服务器)

CDN 内容分发网络。



mpaas 服务架构图 sba服务化架构_数据_02

6、构建高性能的分布式架构