dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
参考:https://github.com/Snailclimb/JavaGuide/blob/master/docs/system-design/data-communication/dubbo.md
上述节点简单说明:
调用关系说明:
重要知识点总结:
参考:https://blog.csdn.net/yiyijianxian/article/details/98071124?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase
一共有4种负载均衡策略:
dubbo默认的负载均默认是随机调用法。
配置方式:可以在服务级别配置,也可以在方法级别配置。分为xml 配置方式和注解方式。
xml 配置方式
服务级别
provider端:
consumer端:
方法级别
provider端
consumer端
也可以使用注解的方式进行配置。
@Service
public class OrderServiceImpl implements OrderService {
//@Autowired
@Reference(loadbalance="roundrobin")
UserService userService;
参考:https://blog.csdn.net/zhengzhaoyang122/article/details/80884535
集群容错的场景:通信链路故障,指消费者和服务提供者之间的链路(通常为长连接)中断;服务端超时,当服务端无法在指定时间内应答给客户端;超时、流控、解码失败等系统异常造成的服务端调用失败。
消费者根据配置的路由策略选择某个目标地址之后,发起远程服务调用,在此期间如果发生远程服务调用异常,则需要框架进行集群容错,重新进行选路和调用,集群容错是系统自动执行的,上层用户并不关心底层的服务调用过程。
dubbo容错机制的种类
1、Failover:失败自动切换,当出现失败,重试其它服务器 。
应用场景进行总结:
1)、读操作,因为通常它是幂等的。
2)、幂等性服务,保证调用1次与N次效果相同。
因为重试会带来更长延迟。可通过 retries="2" 来设置重试次数(不含第一次)。
集群配置如下:
或
2、Failfast:快速失败,只发起一次调用,失败立即报错。
通常用于写入审计日志等操作。
或
3、Failsafe:失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作。
或
4、Failback:失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作。
或
5、Forking:并发处理。并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过forks="2"来设置最大并行数。
或
6、Broadcast: 广播调用所有提供者,逐个调用,任意一台报错则报错。(2.1.0开始支持)。通常用于通知所有提供者更新缓存或日志等本地资源信息。
或
参考:https://segmentfault.com/a/1190000019896723#item-6
在实际生产中,假如zookeeper注册中心宕掉,一段时间内服务消费方还是能够调用提供方的服务的,实际上它使用的本地缓存进行通讯,这只是dubbo健壮性的一种体现。
dubbo的健壮性表现:
我们前面提到过:注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小。所以,我们可以完全可以绕过注册中心——采用 dubbo 直连 ,即在服务消费方配置服务提供方的位置信息。
可以看到,只要在消费端在 dubbo:reference
节点使用 url
给出服务端的方法即可。
参考:https://www.jianshu.com/p/098dd5876381
由于网络原因或者自身的原因,服务并不能保证100%的可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,servlet容器的线程资源就会消耗完毕,导致服务瘫痪。服务之间与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重的后果,这就是服务故障的“雪崩”效应。
如果我们检查出来某个请求频繁的超时,就把consumer调用provider的请求直接短路掉,不实际调用,而是直接返回一个mock的值。等provider服务恢复稳定之后,重新调用。
Netflix 开源了 Hystrix 组件,实现了熔断器模式,Spring Cloud 对这一组件进行了整合。
当服务器压力剧增的情况下,根据实际业务情况以及流量,对一些服务和页面有策略的不处理或者换种简单的方式处理,从而释放服务器资源以保证核心交易正常运转或高效运作。
可以通过服务降级功能临时屏蔽某个出错的非关键服务,并定义降级后的返回策略。
参考:https://blog.csdn.net/u012965203/article/details/98253914
为了防止某个消费者的QPS或是所有消费者的QPS的总和突然飙升而导致的重要服务的失效,系统可以对访问流量进行控制,这种对集群的保护措施称为服务限流。
Dubbo中能够实现服务限流的方式可以划分为两类:直接限流与间接限流。
中文文档:http://dubbo.apache.org/zh-cn/docs/user/quick-start.html