dubbox 学习
目录
编译源码
dubbox是没有安装包的,所以我们只能先下载源码
直接从最新源码下载的话 可能会有各种问题,所以一定要选择一个发行版来下载 地址:https://github.com/dangdangdotcom/dubbox/releases
下载后就开始编译吧
mvn install maven.test.skip=true
发布dubbo的jar包到私库
dubbo的jar包在 dubbo/target/dubbo-2.x.x.jar (应该是2.8以上的版本)
然后将该jar包发布到私库(关于私库搭建相关参照 如何上传jar包到第三方仓库 )
mvn deploy:deploy-file \
-DgroupId=com.alibaba \
-DartifactId=dubbo \
-Dversion=.x.x \
-Dpackaging=jar \
-Dfile=dubbo/target/dubbo-.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)
<role rolename="tomcat"/>
<role rolename="role1"/>
<user username="tomcat" password="tomcat" roles="tomcat,manager-gui"/>
<user username="both" password="tomcat" roles="tomcat,role1"/>
<user username="role1" password="tomcat" roles="role1"/>
</tomcat-users>
我们还需要修改解压后的配置文件:进入解压后的目录,编辑WEB-INF/dubbo.properties
dubbo.registry.address=zookeeper://192.168.0.216,192.168.0.217,192.168.0.218
dubbo.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-monitor
dubbo.application.owner=Ray
dubbo.registry.address=zookeeper://192.168.0.216,192.168.0.217,192.168.0.218
dubbo.protocol.port= # Database Settings
db.url=jdbc:mysql://192.168.0.250:3306/monitor?prepStmtCacheSize=517&cachePrepStmts=true&autoReconnect=true&characterEncoding=utf-8
db.username=root
db.password=
db.maxActive= # System Manager
manager.username=admin
manager.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:
spring:
dubbo:
application:
name: business-provider
registry:
protocol: zookeeper
address: node1:,node2:,node3:
protocol:
name: dubbo
port:
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
@Controller
public 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:
spring:
dubbo:
application:
name: business-consumer
registry:
protocol: zookeeper
address: node1:,node2:,node3:
scan: cn.veryjava.business.consumer.controller
其他
1.Dubbo消费者启动报错 Failed to check the status of the service
出现这个错误的时候,在dubbo admin中查看消费者,显示没有提供者(但提供者运行正常且可访问)
我的原因是消费者没有指定服务版本,在消费者配置文件引用服务的时候加上服务版本即可(提供者的@Service注解)
<dubbo:reference id="testService" version="1.0.0" interface="com.product.service.ITestService" />
参考:
dubbox 学习的更多相关文章
- dubbo学习 三 dubbox概述
当当网根据自身的需求,对dubbo进行了扩展就叫成了dubbox.具体的使用方法可以参照官网各种例子:http://dangdangdotcom.github.io/dubbox/ 支持rest风 ...
- 分布式服务框架 dubbo/dubbox 入门示例
dubbo是一个分布式的服务架构,可直接用于生产环境作为SOA服务框架. 官网首页:http://dubbo.io/ ,官方用户指南 http://dubbo.io/User+Guide-zh.htm ...
- dubbox
github源码: https://github.com/dangdangdotcom/dubbox maven中央仓: 无 获取分支 git clone -b dubbox-2.8.4 https: ...
- dubbox开发rest+json指南【转】
http://dangdangdotcom.github.io/dubbox/rest.html 目录 概述 REST的优点 应用场景 快速入门 标准Java REST API:JAX-RS简介 RE ...
- 分布式服务框架 dubbo/dubbox 入门示例(转)
dubbo是一个分布式的服务架构,可直接用于生产环境作为SOA服务框架. 官网首页:http://dubbo.io/ ,官方用户指南 http://dubbo.io/User+Guide-zh.htm ...
- dubbo和dubboX与微服务架构(dubbo一)
一.传统三层架构模式的缺陷 三层架构(3-tier architecture) 通常意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)web.业务逻辑层(Bu ...
- 一个入门rpc框架的学习
一个入门rpc框架的学习 参考 huangyong-rpc 轻量级分布式RPC框架 该程序是一个短连接的rpc实现 简介 RPC,即 Remote Procedure Call(远程过程调用),说得通 ...
- 服务化实战之 dubbo、dubbox、motan、thrift、grpc等RPC框架比较及选型
转自: http://blog.csdn.net/liubenlong007/article/details/54692241 概述 前段时间项目要做服务化,所以我比较了现在流行的几大RPC框架的优缺 ...
- javaWeb后端学习记录
java后端学习重点: 1.java语言特性: 基础知识,集合,多线程,并发,JVM,NIO,网络编程,设计模式. (★★★★★) jdk源码中有大量的数据结构与java语言细节.jdk源码着重看c ...
随机推荐
- ECMAScript/JS 基础知识讲解
闭包 下面这个方法能输入0 1 2 ... 9吗?显然是不可以的,输出结果是10个10. function test() { var arr = []; for(var i = 0; i < 1 ...
- centos添加定时任务
安装crontab: yum install crontabs 查看crontab服务状态:service crond status 手动启动crontab服务:service crond start ...
- 常用模块一(random模块、time模块、sys模块)
一.random模块 import random # 1 取随机小数 应用:数学计算 ret = random.random() # 大于0且小于1之间的小数 print(ret) # 0.53559 ...
- MySQL如何优化GROUP BY :松散索引扫描 VS 紧凑索引扫描
执行GROUP BY子句的最一般的方法:先扫描整个表,然后创建一个新的临时表,表中每个组的所有行应为连续的,最后使用该临时表来找到组 并应用聚集函数.在某些情况中,MySQL通过访问索引就可以得到结果 ...
- nodejs koa2 获取get值和post值,提交表单
// 获取get值 router.get('/b', async(ctx, next) => { ctx.state = { title: 'Koa2', name: '小明-list' } l ...
- k8s 安装文档
k8s 安装文档 1.5 http://blog.csdn.net/bobpen/article/details/78958675
- JavaWeb—监听器Listener
1.简介 Listener是Servlet的监听器,Servlet 监听器用于监听一些重要事件的发生,监听器对象在事情发生前.发生后可以做一些必要的处理. JavaWeb里面的listener是通过观 ...
- Java中的异常和处理详解(转发:https://www.cnblogs.com/lulipro/p/7504267.html)
简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函数返回值作为执行状态?. ...
- 方阵行列式并行化计算(OpenMP,MPI),并计算加速比
00][100].在创建方阵时,方阵的阶数N(N<100)由外部输入.然后用两层"for循环"来给方阵 p左上角 N×N个位置赋值.具体实现如下: /* * 定义矩阵阶数N ...
- C#如何打印RichTextBox控件的内容
本任务的内容 摘要 创建 RichTextBoxPrintCtrl 控件 测试控件 参考 概要 本分步指南介绍了如何打印 RichTextBox 控件的内容.RichTextBox 控件没有提供任 ...