Dubbo配置问题-2

目录

配置优先级别
1.dubbo的多版本支持
2.主机绑定过程分析
3.集群容错
4.服务降级

\color{red}{配置的优先级别是什么呢?}

客户端的配置优先于服务端
1.方法级优先,接口级次之,全局配置再次之。
2.如果级别一样,则消费方优先,提供方次之。

其中,服务提供方配置,通过URL经由注册中心传递给消费方.
关于哪些配置由服务端配置哪些配置由客户端配置一般看谁更清楚业务吧,比如超时配置一般服务端设置,因为一个方法需要执行多长时间,服务提供方更清楚,如果一个消费方同时引用多个服务,就不需要关心每个服务的超时设置。


1.多版本支持

当服务提供者提供的服务接口出现不兼容升级时,可以设置版本号,使用多个版本号(version)进行过渡。
可以按照以下的步骤进行版本迁移:

  • 在低压力时间段,先升级一半提供者为新版本
  • 再将所有消费者升级为新版本
  • 然后将剩下的一半提供者升级为新版本

如图,我们在服务端配置了俩实现类,并均对外提供服务

反映到Zk注册中心,看一下provider

发现服务已经注册上去,这里我们在客户端进行配置看看有没有用,结果如下,显然有用.
<dubbo:reference id="cliRes" interface="com.zyh.dubbo.ApiInterface" check="false" version="1.0.0"/>
<dubbo:reference id="cliRes" interface="com.zyh.dubbo.ApiInterface" check="false" version="1.0.1"/>

ps:对于配置了版本号的服务,我们在客户端一定要指定版本号哦.否则就是ERROR

2.主机绑定过程分析

我们服务端在发布url时对于ip的获取经历了许多过程.
具体在源码中体现.在dubbo-config模块的ServiceConfig源码中有一列的判断和尝试.即在生成绑定的主机的时候,会通过一层一层的判断和不断的尝试,直到获取到合法的ip地址。|

1. NetUtils.isInvalidLocalHost(host), 从配置文件中获取st

2. 尝试从网卡拿host = InetAddress.*getLocalHost*().getHostAddress();

3. 尝试利用socket连接注册中心得到地址
try {
    SocketAddress addr = new InetSocketAddress(registryURL.getHost(), registryURL.getPort());
    socket.connect(addr, 1000);
    host = socket.getLocalAddress().getHostAddress();
    break;
} finally {
    try {
        socket.close();
    } catch (Throwable e) {}
}
4. 最后拿不到可能会从本地网卡拿
public static string getLocalHost () {
InetAddress address = getLod lAddress (); 
return address = null ? LOCALHOST : address. getHostAddress ();
}

3.集群容错

什么是容错机制? 容错机制指的是某种系统控制在一定范围内的一种允许或包容犯错情况的发生,举个简单例子,我们在电脑上运行一个程序,有时候会出现无响应的情况,然后系统会弹出一个提示框让我们选择,是立即结束还是继续等待,然后根据我们的选择执行对应的操作,这就是“容错”。
在分布式架构下,网络、硬件、应用都可能发生故障,由于各个服务之间可能存在依赖关系,如果一条链路中的其中一个节点出现故障,将会导致雪崩效应。为了减少某一个节点故障的影响范围,所以我们才需要去构建容错服务,来优雅的处理这种中断的响应结果.

Dubbo提供了6种容错机制,官方文档
  • 1.failsafe 失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作。
  • 2.failover(默认) 失败自动切换,当出现失败,重试其它服务器。通常用于读操作,但重试会带来更长延迟。可通过 retries="2" 来设置重试次数(不含第一次)。一般用于查询操作.
    重试次数配置如下:<dubbo:service retries="2" /><dubbo:reference retries="2" /><dubbo:reference><dubbo:method name="findFoo" retries="2" /></dubbo:reference>
  • 3.failfast 快速失败,只发起一次调用,失败立即报错。通常用于非幂等性的写操作,比如新增记录。一般适用于增删改这样的事务操作.
  • 4.failback 失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作或者增删改这样的事务操作。
  • 5.forking forks. 设置并行数, 并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks="2" 来设置最大并行数。
  • 6.broadcast 广播,广播调用所有提供者,逐个调用,任意一台报错则报错通常用于通知所有提供者更新缓存或日志等本地资源信息。
配置方法,通过cluster方式,配置指定的容错方案

按照以下示例在服务提供方和消费方配置集群模式

<dubbo:service cluster="failsafe" />
或
<dubbo:reference cluster="failsafe" />

4.服务降级

降级措施配置: Mock

降级的目的是为了保证核心服务可用。
降级可以有几个层面的分类: 自动降级和人工降级;
按照功能可以分为:读服务降级和写服务降级;
1.对一些非核心服务进行人工降级,在大促之前通过降级开关关闭哪些推荐内容、评价等对主流程没有影响的功能
2.故障降级,比如调用的远程服务挂了,网络故障、或者RPC服务返回异常。 那么可以直接降级,降级的方案比如设置默认值、采用兜底数据(系统推荐的行为广告挂了,可以提前准备静态页面做返回)等等
限流降级,在秒杀这种流量比较集中并且流量特别大的情况下,因为突发访问量特别大可能会导致系统支撑不了。这个时候可以采用限流来限制访问量。当达到阀值时,后续的请求被降级,比如进入排队页面,比如跳转到错误页(活动太火爆,稍后重试等)

这里提供一个示例,我们在客户端(服务端也可配置)对ApiInterface(降级类要实现这个接口)的接口调用进行配置一个超时降级措施,仅需配置引用方法的降级类就好.
超时调用类

public class AppMock implements ApiInterface {
    @Override
    public String returnName(String s) {
        return "系统繁忙,请稍后再试: "+s;
    }
}

配置

<dubbo:reference id="cliRes" interface="com.zyh.dubbo.ApiInterface" check="false"
     mock="com.zyh.dubbo.AppMock" version="1.0.0" timeout="1"/>

这里配置了超时时间为1ms,超过1ms或者系统直接宕机了不管用了,dubbo服务端没返回处理结果我们这里就直接调用配置好的降级类.

ps:注意这里同时配置容错和降级可以能会出现冲突问题.比如failsafe的吞错误会使降级得不到错误降级信号.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352