博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
dubbox 学习
阅读量:6327 次
发布时间:2019-06-22

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

目录

 

编译源码

dubbox是没有安装包的,所以我们只能先下载源码

直接从最新源码下载的话  可能会有各种问题,所以一定要选择一个发行版来下载  地址:

下载后就开始编译吧

mvn install maven.test.skip=true

 

发布dubbo的jar包到私库

dubbo的jar包在 dubbo/target/dubbo-2.x.x.jar (应该是2.8以上的版本)

然后将该jar包发布到私库(关于私库搭建相关参照  )

mvn deploy:deploy-file \  -DgroupId=com.alibaba \  -DartifactId=dubbo \  -Dversion=2.x.x \  -Dpackaging=jar \  -Dfile=dubbo/target/dubbo-2.x.x.jar \  -Durl=http://192.168.0.170:8081/repository/3rd-part/ \  -DrepositoryId=nexus

 

然后将项目的maven源改为私库,这样就可以使用dubbox的jar包了

 

安装dubbo-admin

在dubbo-admin/target下会找到一个war包,这个是dubbox的管理网页,放到tomcat下,启动tomcat会自动解压并运行。

刚安装的tomcat需要设置用户信息才能访问  

编辑文件 tomcat/conf/tomcat-users.xml   (给tomcat用户添加角色manager-gui)

 

我们还需要修改解压后的配置文件:进入解压后的目录,编辑WEB-INF/dubbo.properties

dubbo.registry.address=zookeeper://192.168.0.216,192.168.0.217,192.168.0.218dubbo.admin.root.password=root  dubbo.admin.guest.password=guest

主要是设置dubbo的注册zookeeper地址和访问网站的登录信息(root:root,guest:guest)

 

安装monitor

这里可以使用一个开源的修改版  git clone https://git.oschina.net/handu/dubbo-monitor.git 

下载之后进入目录,有一个sql文件夹,根据sql内容创建数据库和表

然后编辑文件 src/main/resources/application.properties  (设置数据库连接及zookeeper注册地址)

dubbo.application.name=dubbo-monitordubbo.application.owner=Raydubbo.registry.address=zookeeper://192.168.0.216,192.168.0.217,192.168.0.218dubbo.protocol.port=6060# Database Settingsdb.url=jdbc:mysql://192.168.0.250:3306/monitor?prepStmtCacheSize=517&cachePrepStmts=true&autoReconnect=true&characterEncoding=utf-8db.username=rootdb.password=123db.maxActive=500# System Managermanager.username=adminmanager.password=admin

 

Springboot + dubbox + spring-boot-starter-dubbo(provider和customer都是dubbox)

 这种方式是最简单粗暴的,本身通过springboot就已经简化了很多配置和操作,再加上某伙计写的starter,更是6的飞起。

这里简单说说主要的代码,后面附上代码(代码来自参考中的文章,稍有改动)

1.api 这个是服务提供者的接口,消费者也需要依赖这个接口。这里就是普通的接口,没有特别的。

 

2.provider 提供者,需要实现api并指定注册地址及协议、端口等信息

ServiceImpl.java

@Service(version = "1.0.0")public class BusinessServiceImpl implements BusinessService {    @Override    public BusinessDomain findBusiness(int id, String name) {        return null;    }}

 

注意这里的注解 @Service,不是Spring的,而是 com.alibaba.dubbo.config.annotation.Service

通过这个注解可以设定服务的版本、重试次数、甚至是负载均衡策略等。此外,消费端要匹配这个Service中的version

application.yml

server:  port: 8087spring:  dubbo:    application:      name: business-provider    registry:      protocol: zookeeper      address: node1:2181,node2:2181,node3:2181    protocol:      name: dubbo      port: 20880      host: server1.demo.cn    scan: cn.veryjava.business.provider

 

protocol.name是提供服务的协议,这里给的是dubbo,当然也可以用其他的如rest

protocol.host是指定部署服务的IP,当然也可以用hostname代替,如localhost;

registry.address是注册地址,即zookeeper集群的节点信息;

 

3.consumer 消费者

ConsumerController.java

@Controllerpublic class BusinessConsumerController {    @Reference(version = "1.0.0")    public BusinessService businessService;    @RequestMapping("/business")    @ResponseBody    public BusinessDomain getBusiness() {        return businessService.findBusiness(1, "businessaaa");    }}

 

application.yml

server:  port: 8088spring:  dubbo:    application:      name: business-consumer    registry:      protocol: zookeeper      address: node1:2181,node2:2181,node3:2181    scan: cn.veryjava.business.consumer.controller

 

 

 

 

其他

 1.Dubbo消费者启动报错 Failed to check the status of the service

出现这个错误的时候,在dubbo admin中查看消费者,显示没有提供者(但提供者运行正常且可访问)

我的原因是消费者没有指定服务版本,在消费者配置文件引用服务的时候加上服务版本即可(提供者的@Service注解)

 

 

 

 

 

 

参考:

转载于:https://www.cnblogs.com/TiestoRay/p/6594216.html

你可能感兴趣的文章
now()与sysdate()的区别(1)
查看>>
jmeter压力测试值之配置JDBC Connection Configuration(一)
查看>>
linux每日命令(10):touch命令
查看>>
给natp_server加缓存
查看>>
Index Generation
查看>>
多系统通讯-DotNetMQ
查看>>
java之网络编程
查看>>
iOS----应用的旋转---Orientations
查看>>
Apache Ignite高性能分布式网格框架-初探
查看>>
UITextField 光标的位置设置获取
查看>>
技术沙龙记录1
查看>>
月份获取
查看>>
局域网内电脑远程访问共享
查看>>
常用上传shell脚本
查看>>
命令行参数读取和解析
查看>>
禁止浏览器滚动条滚动,但滚动条可以显示
查看>>
nginx + tomcat 集群记录
查看>>
python使用post登陆电子科大信息门户并保存登陆后页面
查看>>
Jquery 常用笔记 (一)
查看>>
全面理解面向对象的 JavaScript
查看>>