博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于spring及zookeeper的dubbo工程搭建
阅读量:5014 次
发布时间:2019-06-12

本文共 8002 字,大约阅读时间需要 26 分钟。

一、生产者搭建

新建一个maven工程,勾选Create a simple project

Packaging方式选择jar包的方式。

修改pom.xml文件:

4.0.0
com.shaw
provider
1.0.0
4.3.2.RELEASE
com.alibaba
dubbo
2.5.3
org.springframework
spring
com.github.sgroschupf
zkclient
0.1
org.springframework
spring-core
${spring.version}
org.springframework
spring-beans
${spring.version}
org.springframework
spring-context
${spring.version}
org.springframework
spring-jdbc
${spring.version}
org.springframework
spring-web
${spring.version}
org.springframework
spring-webmvc
${spring.version}
org.springframework
spring-aop
${spring.version}
org.springframework
spring-tx
${spring.version}
org.springframework
spring-orm
${spring.version}
org.springframework
spring-context-support
${spring.version}
org.springframework
spring-test
${spring.version}
org.springframework
spring-jms
${spring.version}

按照如图的方式,创建相关目录文件

ProviderService.java

package com.shaw.service;public interface ProviderService {     public void sayHello();}

ProviderServiceImpl.java

package com.shaw.service.impl;import com.shaw.service.ProviderService;public class ProviderServiceImpl implements ProviderService{    @Override    public void sayHello() {        System.out.println("Hello!I am Provider!");    }}

TestProviderService.java

package com.shaw.service;import org.springframework.context.support.ClassPathXmlApplicationContext;public class TestProviderService {    public static void main(String[] args) {        ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext(new String[]{
"application.xml"}); context.start(); System.out.println("生产者服务已经注册成功!"); try { System.in.read();//让此程序一直跑,表示一直提供服务 } catch (Exception e) { e.printStackTrace(); } }}

application.xml

按照如下步骤测试生产者:

1、启动zookeeper 

2、启动tomcat  【1、2两点的相关搭建可以参考博主之前的博文】

3、右键TestProviderService类。

地址栏输入:http://localhost:8080/dubbo-admin-2.5.4/ 账户密码为root/root。输入服务名称:com.shaw.service.ProviderService

至此,生产者搭建完成并提供服务了。

二、消费者搭建

按照搭建生产者的过程重新搭建一个consumer的工程:

工程目录如下:

TestConsumerService.java

package com.shaw.consumer;import java.io.IOException;import org.springframework.context.support.ClassPathXmlApplicationContext;import com.shaw.service.ProviderService;public class TestConsumerService {    public static void main(String[] args) {        ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext(new String[]{
"application.xml"}); context.start(); ProviderService testService = (ProviderService) context.getBean("testProviderService"); testService.sayHello(); try { System.in.read(); } catch (IOException e) { e.printStackTrace(); } }}

application.xml

消费者测试:

继续生产者的测试步骤不同的是最后在TestConsumerService类右键。

控制台输入了生产者打印出来的信息:

同时登录:http://localhost:8080/dubbo-admin-2.5.4/ 也可以查看相关消费者的服务信息如图:

三、相关dubbo配置信息

3.1 dubbo常用配置

服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心。  
引用服务配置,用于创建一个远程服务代理,一个引用可以指向多个注册中心。  
协议配置,用于配置提供服务的协议信息,协议由提供方指定,消费方被动接受。  
应用配置,用于配置当前应用信息,不管该应用是提供者还是消费者。  
  
注册中心配置,用于配置连接注册中心相关信息。  
模块配置,用于配置当前模块信息,可选。
监控中心配置,用于配置连接监控中心相关信息,可选。
提供方的缺省值,当ProtocolConfig和ServiceConfig某属性没有配置时,采用此缺省值,可选。
消费方缺省配置,当ReferenceConfig某属性没有配置时,采用此缺省值,可选。
方法配置,用于ServiceConfig和ReferenceConfig指定方法级的配置信息。
用于指定方法参数配置。

3.2 服务调用超时设置

 

 

上图中以timeout为例,显示了配置的查找顺序,其它retries, loadbalance, actives也类似。

方法级优先,接口级次之,全局配置再次之。
如果级别一样,则消费方优先,提供方次之。 

其中,服务提供方配置,通过URL经由注册中心传递给消费方。

建议由服务提供方设置超时,因为一个方法需要执行多长时间,服务提供方更清楚,如果一个消费方同时引用多个服务,就不需要关心每个服务的超时设置。
理论上ReferenceConfig的非服务标识配置,在ConsumerConfig,ServiceConfig, ProviderConfig均可以缺省配置。

3.3 启动时检查 

Dubbo缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止Spring初始化完成,以便上线时,能及早发现问题,默认check=true。

如果你的Spring容器是懒加载的,或者通过API编程延迟引用服务,请关闭check,否则服务临时不可用时,会抛出异常,拿到null引用,如果check=false,总是会返回引用,当服务恢复时,能自动连上。

可以通过check="false"关闭检查,比如,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动。 

1、关闭某个服务的启动时检查:(没有提供者时报错)
2、关闭所有服务的启动时检查:(没有提供者时报错) 写在定义服务消费者一方
3、关闭注册中心启动时检查:(注册订阅失败时报错)

引用缺省是延迟初始化的,只有引用被注入到其它Bean,或被getBean()获取,才会初始化。

如果需要饥饿加载,即没有人引用也立即生成动态代理,可以配置: 

<dubbo:reference interface="com.foo.BarService" init="true" />

3.4 订阅

1、问题
为方便开发测试,经常会在线下共用一个所有服务可用的注册中心,这时,如果一个正在开发中的服务提供者注册,可能会影响消费者不能正常运行。 

2、解决方案

可以让服务提供者开发方,只订阅服务(开发的服务可能依赖其它服务),而不注册正在开发的服务,通过直连测试正在开发的服务。

禁用注册配置:
或者:

3.5 回声测试(测试服务是否可用)

回声测试用于检测服务是否可用,回声测试按照正常请求流程执行,能够测试整个调用是否通畅,可用于监控。

所有服务自动实现EchoService接口,只需将任意服务引用强制转型为EchoService,即可使用。

MemberService memberService = ctx.getBean("memberService"); // 远程服务引用EchoService echoService = (EchoService) memberService; // 强制转型为EchoServiceString status = echoService.$echo("OK"); // 回声测试可用性assert(status.equals("OK"))

3.6 延迟连接

延迟连接,用于减少长连接数,当有调用发起时,再创建长连接。

只对使用长连接的dubbo协议生效。 

<dubbo:protocol name="dubbo" lazy="true" />

3.7 令牌验证
防止消费者绕过注册中心访问提供者,在注册中心控制权限,以决定要不要下发令牌给消费者,注册中心可灵活改变授权方式,而不需修改或升级提供者

1、全局设置开启令牌验证:
2、服务级别设置开启令牌验证:
3、协议级别设置开启令牌验证:

3.8 日志适配

缺省自动查找:log4j、slf4j、jcl、jdk 

可以通过以下方式配置日志输出策略:dubbo:application logger="log4j"/> 

访问日志:

如果你想记录每一次请求信息,可开启访问日志,类似于apache的访问日志。此日志量比较大,请注意磁盘容量。 

将访问日志输出到当前应用的log4j日志: 
将访问日志输出到指定文件:

3.9 配置Dubbo缓存文件 

配置方法如下: 

<dubbo:registryfile=”${user.home}/output/dubbo.cache” />

注意:
文件的路径,应用可以根据需要调整,保证这个文件不会在发布过程中被清除。如果有多个应用进程注意不要使用同一个文件,避免内容被覆盖。 

这个文件会缓存:

注册中心的列表
服务提供者列表 

有了这项配置后,当应用重启过程中,Dubbo注册中心不可用时则应用会从这个缓存文件读取服务提供者列表的信息,进一步保证应用可靠性。

 

本文代码下载:

转载于:https://www.cnblogs.com/shawWey/p/6927141.html

你可能感兴趣的文章
env-update干了些什么
查看>>
[WPF]使用WindowChrome自定义Window Style
查看>>
windows 下搭建简易nginx+PHP环境
查看>>
正则表达式, 贪婪模式
查看>>
android开发之调试技巧 分类: android ...
查看>>
Cordova - 如何安装 PhoneGap / Cordova (for Win10)
查看>>
微信小程序-学习笔记2-页面配置
查看>>
webpackの学习笔记2
查看>>
RobotFramework教程使用笔记——robotframwork中文乱码显示问题
查看>>
[.NET WebAPI系列03] WebAPI Controller 中标准CRUD方法
查看>>
AngularJS
查看>>
linux下elasticsearch集成mongodb详细教程
查看>>
【整理】Virtualbox中的网络类型(NAT,桥接等),网卡,IP地址等方面的设置
查看>>
【转载】Js获取当前日期时间及其它操作
查看>>
批处理安装nodejs
查看>>
Mybatis 动态sql(转载)
查看>>
前端工作面试问题
查看>>
开源分布式实时计算引擎 Iveely Computing 之 安装部署(2)
查看>>
[ CodeForces 17 E ] Palisection
查看>>
CentOS7 安装sentry(最新)
查看>>