一、Dubbo集群容错模式
1、Failover Cluster
失败自动切换,当出现失败,重试其它服务器。(缺省)
通常用于读操作,但重试会带来更长延迟。
2、Failfast Cluster
快速失败,只发起一次调用,失败立即报错。
通常用于非幂等性的写操作,比如新增记录。
3、Failback Cluster
失败自动恢复,后台记录失败请求,定时重发。
通常用于消息通知操作。
4、Forking Cluster
并行调用多个服务器,只要一个成功即返回。
通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过forks="2"来设置最大并行数。
5、Broadcast Cluster
· 广播调用所有提供者,逐个调用,任意一台报错则报错。(2.1.0开始支持)
· 通常用于通知所有提供者更新缓存或日志等本地资源信息。
二、Dubbo服务划分
1、服务划分目标
抽取系统中独立的业务模块服务化,按业务独立性进行垂直划分,抽象出基础服务层
2、子系统划分把控:合理划分,过细过粗都不行
3、注意事项
1)表:避免出现A服务关联B服务的表的数据操作;服务一旦划分了,那么数据库即便没分开,也要当成db表分开了来进行编码;否则AB服务难以进行垂直拆库
2)避免服务耦合度高,依赖调用;如果出现,考虑服务调优。
3)避免分布式事务,不要拆分过细。
三、Dubbo接口划分
1、接口尽可能大粒度,接口中的方法不要以业务流程来,这个流程尽量在方法逻辑中调用,接口应代表一个完整的功能对外提供;
2、接口应以业务为单位,业务相近的进行抽象,避免接口数量爆炸
3、参数先做校验,在传入接口。
4、要做到在设计接口时,已经确定这个接口职责、预测调用频率
四、Dubbo服务高级特性
1、启动检查
在启动某服务时,先检查该服务所依赖的服务是否可用,不可用则抛出异常,以便上线时,能及早发现问题,默认check=“true”;
2、负载均衡
针对某一方法在db管控台进行配置-
负载算法:随机(Random LoadBalance)、轮循(RoundRobin)、最少活跃调用数(LeastActive ,越活跃接收请求的概率越大)、一致性hash(ConsistentHash )
3、线程模型:threadpool threads
最大线程数计算方式 ulimit -u命令计算服务器可执行最大线程数
4、直连提供者
指定连接local的服务,不对生产环境造成影响 url="localhost:20818“
5、只订阅
只订阅服务,自己不注册,例如该服务正在测试,先不能向zk中注册避免其他服务调用它报错
6、只注册
只注册服务,不订阅;应用在集群中该服务器上无该服务需要调用的服务,就让他只注册,指定调用其它服务器上的可用服务