Dubbo Configuration
可配置参数
http://dubbo.apache.org/zh-cn/docs/user/references/xml/introduction.html
与 spring 整合的几种方式
SpringBoot 与 dubbo 整合的三种方式: http://dubbo.apache.org/zh-cn/docs/user/configuration/annotation.html
1)、导入 dubbo-starter,在 application.properties 中配置属性
使用 @Service【暴露服务】使用 @Reference【引用服务】使用 @EnableDubbo【开启扫描,相当于配置 dubbo.scan.base-packages】 http://dubbo.apache.org/zh-cn/docs/user/configuration/xml.html
2)、导入 dubbo-starter,保留 dubbo xml 配置文件(这样可保留方法级别的配置)
在启动类上使用 @ImportResource(locations="classpath:dubbo.xml") 导入 dubbo 的配置文件即可 http://dubbo.apache.org/zh-cn/docs/user/configuration/api.html
3)、使用注解 API 的方式,将每一个组件手动创建到容器中,让 dubbo 来扫描其他的组件
API 方式配置例子,使用 @Service【暴露服务】使用 @Reference【引用服务】使用【@EnableDubbo】配置 Dubbo 扫描,开启基于注解的 dubbo 功能
package com.gmall.config; import java.util.ArrayList;
import java.util.List; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import com.alibaba.dubbo.config.ApplicationConfig;
import com.alibaba.dubbo.config.MethodConfig;
import com.alibaba.dubbo.config.MonitorConfig;
import com.alibaba.dubbo.config.ProtocolConfig;
import com.alibaba.dubbo.config.ProviderConfig;
import com.alibaba.dubbo.config.RegistryConfig;
import com.alibaba.dubbo.config.ServiceConfig;
import com.gmall.service.UserService; @EnableDubbo(scanBasePackages="com.gmall")
@Configuration
public class MyDubboConfig { @Bean
public ApplicationConfig applicationConfig() {
ApplicationConfig applicationConfig = new ApplicationConfig();
applicationConfig.setName("boot-user-service-provider");
return applicationConfig;
} //<dubbo:registry protocol="zookeeper" address="127.0.0.1:2181"></dubbo:registry>
@Bean
public RegistryConfig registryConfig() {
RegistryConfig registryConfig = new RegistryConfig();
registryConfig.setProtocol("zookeeper");
registryConfig.setAddress("127.0.0.1:2181");
return registryConfig;
} //<dubbo:protocol name="dubbo" port="20882"></dubbo:protocol>
@Bean
public ProtocolConfig protocolConfig() {
ProtocolConfig protocolConfig = new ProtocolConfig();
protocolConfig.setName("dubbo");
protocolConfig.setPort(20882);
return protocolConfig;
} /**
<dubbo:service interface="com.gmall.service.UserService" ref="userServiceImpl01" timeout="1000" version="1.0.0">
<dubbo:method name="getUserAddressList" timeout="1000"/>
</dubbo:service>
*/
@Bean
public ServiceConfig<UserService> userServiceConfig(UserService userService){
ServiceConfig<UserService> serviceConfig = new ServiceConfig<>();
serviceConfig.setInterface(UserService.class);
serviceConfig.setRef(userService);
serviceConfig.setVersion("1.0.0"); //配置每一个method的信息
MethodConfig methodConfig = new MethodConfig();
methodConfig.setName("getUserAddressList");
methodConfig.setTimeout(1000); //将method的设置关联到service配置中
List<MethodConfig> methods = new ArrayList<>();
methods.add(methodConfig);
serviceConfig.setMethods(methods); //ProviderConfig
//MonitorConfig return serviceConfig;
}
}
配置优先级
http://dubbo.apache.org/zh-cn/docs/user/configuration/configuration-load-process.html
JVM参数配置 > 外部化配置 > 代码配置 > 配置文件((dubbo.xml || application.properties) > (dubbo.properties 通常写公共属性配置))
启动时检查
http://dubbo.apache.org/zh-cn/docs/user/demos/preflight-check.html
Dubbo 默认会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止 Spring 初始化完成。
<!--关闭某个服务的启动时检查 (没有提供者时报错)-->
<dubbo:reference interface="com.foo.BarService" check="false"/>
<!--关闭所有服务的启动时检查 (没有提供者时报错)-->
<dubbo:consumer check="false"/>
<!--关闭注册中心启动时检查 (注册订阅失败时报错)-->
<dubbo:registry check="false"/>
超时设置(timeout),默认为一秒(1000ms)
消费者与提供者之间方法调用的时间,超过则会抛出异常,提供者与消费者都可配置,具体生效依据不同粒度配置的覆盖关系,消费方默认超时时间取自提供方。
建议由服务提供方设置超时,因为一个方法需要执行多长时间,服务提供方更清楚,如果一个消费方同时引用多个服务,就不需要关心每个服务的超时设置。
http://dubbo.apache.org/zh-cn/docs/user/references/xml/dubbo-reference.html
<!--
1)、精确优先 (方法级优先,接口级次之,全局配置再次之)
2)、消费者设置优先(如果级别一样,则消费方优先,提供方次之)
--> <!--提供方设置-->
<dubbo:service interface="org.apache.dubbo.demo.DemoService" ref="demoService" timeout="1000"/> <!--提供方设置,精确到方法-->
<dubbo:service interface="org.apache.dubbo.demo.DemoService" ref="demoService">
<dubbo:method name="sayHello" timeout="1000"/>
</dubbo:service> <!--所有提供方默认设置-->
<dubbo:provider timeout="1000"/>
不同粒度配置的覆盖关系
http://dubbo.apache.org/zh-cn/docs/user/configuration/xml.html
以 timeout 为例,下图显示了配置的查找顺序,其它 retries, loadbalance, actives 等类似:
- 方法级优先,接口级次之,全局配置再次之。
- 如果级别一样,则消费方优先,提供方次之。
其中,服务提供方配置,通过 URL 经由注册中心传递给消费方。
重试次数(retries),默认为 2 ,不包含第一次调用,即一共会调用 3 次
消费方默认重试次数设置取自提供方,设置方式与超时设置类似。
http://dubbo.apache.org/zh-cn/docs/user/references/xml/dubbo-service.html
<!-- retries="":重试次数,不包含第一次调用,0代表不重试
幂等操作(可设置重试次数)【如查询、删除、修改】,执行多少次产生的效果一样
非幂等操作(不能设置重试次数)【如新增】
如果该服务有多个,那么当前服务出错后,会重试其它机器上相同的服务,不会一直调用相同地址上的服务
--> <!--提供方设置,精确到方法-->
<dubbo:service interface="org.apache.dubbo.demo.DemoService" ref="demoService">
<dubbo:method name="sayHello" retries="3"/>
</dubbo:service>
多版本设置(灰度发布)
http://dubbo.apache.org/zh-cn/docs/user/demos/multi-versions.html
当一个接口实现,出现不兼容升级时,可以用版本号过渡,版本号不同的服务相互间不引用。
可以按照以下的步骤进行版本迁移:
- 在低压力时间段,先升级一半提供者为新版本
- 再将所有消费者升级为新版本
- 然后将剩下的一半提供者升级为新版本
<!--老版本服务提供者配置-->
<dubbo:service interface="com.foo.BarService" version="1.0.0" />
<!--新版本服务提供者配置-->
<dubbo:service interface="com.foo.BarService" version="2.0.0" /> <!--老版本服务消费者配置-->
<dubbo:reference id="barService" interface="com.foo.BarService" version="1.0.0" />
<!--新版本服务消费者配置-->
<dubbo:reference id="barService" interface="com.foo.BarService" version="2.0.0" /> <!--如果不需要区分版本,可以按照以下的方式配置-->
<dubbo:reference id="barService" interface="com.foo.BarService" version="*" />
本地存根
http://dubbo.apache.org/zh-cn/docs/user/demos/local-stub.html
消费者在调用提供者之前可以做一些操作,来决定要不要调用提供者(就是为具体实现创建一个代理对象)
以之前的 HelloWord 为例,为 DemoService 创建本地存根(一般在接口项目中创建)
package org.apache.dubbo.demo; public class DemoServiceStub implements DemoService { private final DemoService demoService; // 构造函数传入真正的远程代理对象
public DemoServiceStub(DemoService demoService){
this.demoService = demoService;
} @Override
public String sayHello(String name) {
// 此代码在客户端执行, 你可以在客户端做ThreadLocal本地缓存,或预先验证参数是否合法,等等
try {
System.out.println("DemoServiceStub.....");
return demoService.sayHello(name);
} catch (Exception e) {
// 你可以容错,可以做任何AOP拦截事项
return "容错数据";
}
}
}
配置,消费方和提供方都可以配置,这里在消费方配置。
<dubbo:reference id="demoService" interface="org.apache.dubbo.demo.DemoService" stub="org.apache.dubbo.demo.consumer.DemoServiceStub"/> <!--或者-->
<dubbo:reference id="demoService" interface="org.apache.dubbo.demo.DemoService" stub="true"/>
Dubbo Configuration的更多相关文章
- springboot+dubbo
使用springboot搭建dubbo服务,首先封装出springboot-dubbo的项目,引入在服务上加直接@Service直接使用,方便于拆封统一管理. package hello.dubbo. ...
- 解决Dubbo 2.7.3版本使用ConfigCenterConfig集成Apollo No Provider found的问题
Dubbo 2.7.3 集成Apollo 问题描述 Dubbo 2.7.3支持配置中心外部化配置, 因此只需要定义一个ConfigCenterConfig的Bean. @EnableDubbo(sca ...
- Configuration problem: Unable to locate Spring NamespaceHandler for XML schema namespace [http://dubbo.apache.org/schema/dubbo]
dubbo的官方文档写的真好, http://dubbo.apache.org/zh-cn/docs/2.7/user/dependencies/ 在使用dubbo过程中的问题, 和解决 org.sp ...
- Maven多模块,Dubbo分布式服务框架,SpringMVC,前后端分离项目,基础搭建,搭建过程出现的问题
现互联网公司后端架构常用到Spring+SpringMVC+MyBatis,通过Maven来构建.通过学习,我已经掌握了基本的搭建过程,写下基础文章为而后的深入学习奠定基础. 首先说一下这篇文章的主要 ...
- Dubbo 备注
Dubbo是阿里开源的一款服务治理中间件,主要包含如下节点: Provider: 暴露服务的服务提供方. Consumer: 调用远程服务的服务消费方. Registry: 服务注册与发现的注册中心. ...
- Running Dubbo On Spring Boot
Dubbo(http://dubbo.io/) 是阿里的开源的一款分布式服务框架.而Spring Boot则是Spring社区这两年致力于打造的简化Java配置的微服务框架. 利用他们各自优势,配置到 ...
- 基于Dubbo框架构建分布式服务(二)
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> ...
- Spring Boot整合Dubbo框架demo
Dubbo框架原理见之前的博文:http://www.cnblogs.com/umgsai/p/5836925.html 首先启动zookeeper Server端 Pom配置如下 <?xml ...
- 第一章,阿里的Dubbo完美初级搭建,待续。。。
1.1 后台工程搭建分析 Web工程. Maven的常见打包方式:jar.war.pom Pom工程一般都是父工程,管理jar包的版本.maven插件的版本.统一的依赖管理.聚合工程. Taotao- ...
随机推荐
- 06 Django之模型层---多表操作
一 创建模型 表和表之间的关系 一对一.多对一.多对多 ,用book表和publish表自己来想想关系,想想里面的操作,加外键约束和不加外键约束的区别,一对一的外键约束是在一对多的约束上加上唯一约束. ...
- spring cloud 入门
某种程度上 软硬件 殊途同归了 (软件模仿硬件 总线设计, 资源定位 (寻址) ) spring 是什么 EDA ( Event-driven architecture ) (SOA , SOAP , ...
- Clang调试CUDA代码
Clang调试CUDA代码全过程 有空再进行编辑,最近有点忙,抱歉 使用的llvm4.0+Clang4.0的版本,依据的是上次发的llvm4.0和clang4.0源码安装的教程https://www. ...
- python爬去虎扑数据信息,完成可视化
首先分析虎扑页面数据 如图我们所有需要的数据都在其中![image.png](1)所以我们获取需要的内容直接利用beaitifulsoupui4``` soup.find_all('a',class_ ...
- multipart/form-data请求与文件上传的细节
<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...
- Can you answer these queries? HDU - 4027 (线段树,区间开平方,区间求和)
A lot of battleships of evil are arranged in a line before the battle. Our commander decides to use ...
- uestc summer training #2
A 增广 #include<bits/stdc++.h> using namespace std; + ; vector<int> g[MAXN]; int a[MAXN], ...
- python生成器并行实例
生成器并行实例: send发送值被yield接受到赋值给baozi变量 #yield作用只是在这里保存这个值的当前状态然后返回之后在调用next,又回到yield #单纯调用next不会给yield传 ...
- 高性能mysql 第5章 创建高可用的索引
b-tree索引 一定程度上说,mysql只有b-tree索引.他没有bitmap索引.还有一个叫hash索引的,只在Memory存储引擎中才有. b-tree索引跟oracle中的大同小异. mys ...
- BZOJ4004 [JLOI2015]装备购买[贪心+线性基+高消]
一个物品可以被其他物品表出,说明另外的每个物品看成矩阵的一个行向量可以表出该物品代表的行向量. 于是构造矩阵,求最多选多少个物品,就是尽可能用已有的物品去表示,相当于去消去一些没必要物品, 类似于xo ...