Dubbo——配置
一、配置原则
JVM 启动 -D 参数优先,这样可以使用户在部署和启动时进行参数重写,比如在启动时需改变协议的端口。
XML 次之,如果在 XML 中有配置,则 dubbo.properties 中的相应配置项无效。
Properties 最后,相当于缺省值,只有 XML 没有配置时,dubbo.properties 的相应配置项才会生效,通常用于共享公共配置,比如应用名。
二、启动检查
默认情况下,dubbo将检查服务提供者在启动时是否可用。当Spring完全初始化不可用时,它将抛出一个异常以防止Spring完成初始化,以便在发布应用程序(默认设置)之前尽早发现问题:check=true
.
你可以关掉检查check=false
...例如,有些服务在运行测试时不关心它,或者由于循环依赖关系,必须首先启动测试。
此外,如果Springbean是延迟加载的,或者使用API编程延迟引用服务,则关闭检查,否则服务将在服务暂时不可用时抛出异常,然后获得一个空引用。如果您配置check=false
,你可以得到一个推荐信。还原服务后,服务可以自动重新连接。
2.1 使用Spring配置文件
禁用服务的启动检查(在没有提供提供程序时抛出一些异常/错误):
<dubbo:reference interface = "com.foo.BarService" check = "false" />
禁用所有服务的启动检查(未提供时抛出一些异常/错误):
<dubbo:consumer check = "false" />
禁用注册中心启动检查(注册订阅失败错误):
<dubbo:registry check="false" />
2.2 使用dubbo.properties
dubbo.reference.com.foo.BarService.check = false
dubbo.reference.check = false
dubbo.consumer.check = false
dubbo.registry.check = false
2.3 使用-d参数
java -Ddubbo.reference.com.foo.BarService.check = false
java -Ddubbo.reference.check = false
java -Ddubbo.consumer.check = false
java -Ddubbo.registry.check = false
三、超时时间
由于网络或服务端不可靠,会导致调用出现一种不确定的中间状态(超时)。为了避免超时导致客户端资源(线程)挂起耗尽,必须设置超时时间。(默认1秒)
3.1 dubbo消费端
全局超时配置
<dubbo:consumer timeout="5000" /> 指定接口以及特定方法超时配置
<dubbo:reference interface="com.foo.BarService" timeout="2000">
<dubbo:method name="sayHello" timeout="3000" />
</dubbo:reference>
3.2 dubbo服务端
全局超时配置
<dubbo:provider timeout="5000" /> 指定接口以及特定方法超时配置
<dubbo:provider interface="com.foo.BarService" timeout="2000">
<dubbo:method name="sayHello" timeout="3000" />
</dubbo:provider>
3.3 配置原则
3.3.1 dubbo推荐在Provider上尽量多配置Consumer端属性:
1、作服务的提供者,比服务使用方更清楚服务性能参数,如调用的超时时间,合理的重试次数,等等
2、在Provider配置后,Consumer不配置则会使用Provider的配置值,即Provider配置可以作为Consumer的缺省值。否则,Consumer会使用Consumer端的全局设置,这对于Provider不可控的,并且往往是不合理的
3.3.2 配置覆盖规则
1、方法级配置别优于接口级别,即小Scope优先
2、Consumer端配置 优于 Provider配置 优于 全局配置,
3、 最后是Dubbo Hard Code的配置
四、重试次数
当出现故障时,重试另一台服务器(默认)。通常用于幂等操作,但重试会导致更长的延迟。重试的时间可以通过retries =2
(第一次除外)
配置:
<dubbo:service retries="2" />
或:
<dubbo:reference retries="2" />
或:
<dubbo:reference>
<dubbo:method name="findFoo" retries="2" />
</dubbo:reference>
幂等和非幂等区别:https://www.cnblogs.com/lzc978/p/10386122.html
五、版本号
当接口实现不兼容升级时,可以使用版本号转换。不同版本的服务不相互引用。(灰度发布)
可以按照以下步骤进行版本迁移:
- 在低压阶段,升级到提供程序的一半到新版本。
- 然后将所有消费者升级到新版本。
- 然后将其余的一半提供程序升级到新版本。
5.1 服务提供者配置的旧版本:
<dubbo:service interface="com.foo.BarService" version="1.0.0" />
5.2 新版本的服务提供者配置:
<dubbo:service interface="com.foo.BarService" version="2.0.0" />
5.3 服务使用者配置的旧版本:
<dubbo:reference id="barService" interface="com.foo.BarService" version="1.0.0" />
5.4 新版本的服务使用者配置:
<dubbo:reference id="barService" interface="com.foo.BarService" version="2.0.0" />
5.5 如果不需要区分版本,可以按以下方式配置:
<dubbo:reference id="barService" interface="com.foo.BarService" version="*" />
六、本地存根
当使用RPC时,客户端通常只使用接口,但有时客户端也希望在客户机中执行部分逻辑。例如:执行ThreadLocalcache,验证参数,在调用失败时返回模拟数据,等等。
为了解决这个问题,您可以在api中配置存根,以便当客户端生成代理实例时,它将代理传递给Stub
通过构造函数,然后可以在存根实现代码中实现您的逻辑。
6.1 在Spring配置文件中配置如下:
<dubbo:service interface="com.foo.BarService" stub="true" />
或
<dubbo:service interface="com.foo.BarService" stub="com.foo.BarServiceStub" />
6.2 提供Stub实现
package com.foo;
public class BarServiceStub implements BarService {
private final BarService barService; // The real remote proxy object is passed in through the constructor
public BarServiceStub(BarService barService){
this.barService = barService;
} public String sayHello(String name) {
// The following code is executed on the client. You can do local ThreadLocal caching on the client side, or verify parameters, etc.
try {
return barService.sayHello(name);
} catch (Exception e) {
// You can return the mock data.
return "MockData";
}
}
}
Stub必须有一个可以传递代理的构造函数。
BarServiceStub实现BarService,它有一个在远程BarService实例中传递的构造函数
Dubbo——配置的更多相关文章
- Dubbo配置方式详解
Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是阿里巴巴 SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次 ...
- DUBBO配置规则详解
研究DUBBO也已经大半年了,对它的大部分源码进行了分析,以及对它的内部机制有了比较深入的了解,以及各个模块的实现.DUBBO包含很多内容,如果想了解DUBBO第一步就是启动它,从而可以很好的使用它, ...
- [转载,感觉写的非常详细]DUBBO配置方式详解
[转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供 ...
- dubbo配置清单-超详细版
服务发布者 在服务发布者的springboot主配置文件application.properties中添加dubbo配置 #dubbo服务名 spring.dubbo.application.name ...
- dubbo配置约束
此处主要记录dubbo配置的一些约束规则. 采用官网提供的原文,描述如下: 一.XML配置(官网原文) 以 timeout 为例: 方法级优先,接口级次之,全局配置再次之. 如果级别一样,则消费方优先 ...
- dubbo配置指南
dubbo配置指南 SLA配置在此完成!Service Layer Agreement ApplicationConfig 应用配置,用于配置当前应用信息,不管该应用是提供者还是消费者. Regist ...
- Dubbo配置注册中心设置application的name使用驼峰命名法存在的隐藏项目启动异常问题
原创/朱季谦 首先,先提一个建议,在SpringBoot+Dubbo项目中,Dubbo配置注册中心设置的application命名name的值,最好使用xxx-xxx-xxx这样格式的,避免随便使用驼 ...
- 10 Dubbo 配置实战
Dubbo 配置实战 快速入门 dubbo 建议看这篇文章是在学习了快速入门 dubbo 那篇文章的基础上来学习 配置说明 文档地址 https://dubbo.apache.org/zh/index ...
- dubbo 配置解析
1.dubbo 常用配置 <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心.eg.<dub ...
- dubbo配置
Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合).从服务模型的角度来看,Dubbo采用的是一种非常简单的模 ...
随机推荐
- CentOS7.5 安装MySql教程
CentOS7位安装MySql教程 1.先检查系统是否装有mysql rpm -qa | grep mysql 2.下载mysql的repo源 wget http://repo.mysql.com/m ...
- 线段树 面积并问题 hdu 1255 1542
重点整理面积并的思想 以及PushUp的及时更新 还有就是cover的实现 以及建树每个节点存的信息(每个节点存的是一个线段的信息) http://www.tuicool.com/articles/6 ...
- XML和JSON序列化以及反序列化
1.将文件保存序列化至文档中,然后再读取: //首先创建可序列化的实体类 [Serializable] public class Message { public string Name { get; ...
- VS2017清除工具、用于清除Microsoft Visual Studio最近打开项目
最近每天在用VS2017,但是每次打开它都会弹出最近项目的记录,很是烦人. 最主要是我不想别人得知我最近的项目和项目进度,每次加密项目会比较麻烦. 所以经过简单的研究,编写了这个小工具,打开直接单击就 ...
- python基础之迭代器协议和生成器(一)
一 递归和迭代 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前 ...
- BPM软件_财务报销流程管理解决方案_K2工作流引擎
财务报销,对任何企业都是日常运营中重要的一个环节.但报销流程周期长,反复签字手续繁杂,报销过程不透明 ,单据归档保存.检索困难等问题也让员工头疼.为了解决这些困扰,财务报销流程电子化一时成为热门之选. ...
- 下拉框选择 <from:select>
- eclipse导入项目后出现红色叉号的解决方案
对于一名程序员来说,我导入的项目在项目的名称上无端加了一个红色的叉号,虽然这个不友好的符号,对于我整个的项目运行没有任何影响,但是总让我觉得不舒服,大大的叉号写在我的项目的脑袋上,我心里能舒服吗?于是 ...
- 【JavaWeb】通过邮件找回密码
前言 本文将介绍忘记密码时通过发送重置密码邮件找回密码的实现思路.整个实现过程中最重要的就是以下三点: 如何发送邮件到用户指定邮箱 邮件中的重置密码链接构成是怎么样的 验证重置密码链接的合法性(是否过 ...
- rsync & sersync 实时同步
1.根据之前一篇关于rsync的随笔部署好rsync服务后,可以开始inotify的部署 2.sersync的部署 ①.部署服务(安装和配置过程) #Master 部署Sersync服务 mkdir ...