dubbo框架的使用方法。。。
图解。

一、dubbo使用须知。
1.所有的service层必须要使用service注解(之前用的spring框架的,现在用dubbo框架所提供的@Service注解)
// @Service(timeout=单位是秒) 2.在配置dubbo端口号的时候
只是provider项目和consumer项目直接数据通讯的时候所必需的要遵循的端口号
也就是说必须要注意无论是provider还是consumer,所配置的dubbo端口号必须要保持一致
端口号随意定制!!!
1.1.provider的config下的application.properties的配置。 和数据库交互 和consumer 订制dubbo的端口号配置 zookeeper的端口号:2181!!!
server.port=8081
server.context-path=/zxf spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/qy200?useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource mybatis.type-aliases-package=com.aaa.zxf.dubbo.model
mybatis.mapper-locations=classpath:mapper/*Mapper.xml #dubbo 的配置 dubbo的应用名。 在dubbo的项目 可以直接看出改项目是一个什么样的项目
#dubbo-admin 生产者/消费者------application name----需要根据当前项目
#所提供的功能进行命名
dubbo.application.name=user-provider #协议 protocol 配置该项目远程调用的时候所用的协议--dubbo TCP 和 upd..
dubbo.protocol.name=dubbo #配置dubbo 所必需使用的端口号
# 注意!!! provider 和 consumer 所配置的端口号保持一致 号 随意订制。
dubbo.protocol.port=20881 #zookeeper的通讯地址 dubbo框架集成zookeeper
#provider 需要向zookeeper注册服务,要让provider知道 zookeeper是哪一个! #【注意!!!】 dubbo 和 provider 以及 consumer的zookeeper的配置中 所有的zookeeper集群 leader 和 follower都可以配
# 因为最终 无论是leader 还是follower 都可以配 (除非leader 宕机)
# zookeeper的端口号就是 2181 需要保持一致!!
dubbo.registry.address=zookeeper://192.168.132.133:2181 # provider 需要让zookeeper知道 那一个类需要 注册到zookeeper中
#dubbo 包的扫描 改包以及所有的子类 都会注册到zookeeper中
dubbo.scan.base-packages=com.aaa.zxf.dubbo.service.impl # dubbo 根据application 中所配置的dubbo.scan.base-packages 属性来判定 该项目是 provider 还是 consumer #开启我的 zookeeper
1.2 consumer 下的config application.properties的配置。。。 调用provider,负责和用户交互。 HTML 。。。 配置文件中, 少一个对包的扫描!!!
server.port=8084
server.context-path=/zxf #dubbo 的配置
#consumer 中 dubbo的配置和provider中只差了一行 不需要配置扫描包
dubbo.application.name=user-consumer #dubbo的协议名称
dubbo.protocol.name=dubbo #dubbo 的协议端口号 provider 和 consumer 需要保持一致!!!
dubbo.protocol.port=20881 #注册中心的地址 leader 和 follower的ip 都可以!!!
dubbo.registry.address=zookeeper://192.168.132.133:2181 # thymeleaf 开启不严谨的检查方式 需要导入jar包
spring.thymeleaf.mode=LEGACYHTML5 # springboot 使用 thymeleaf 关闭缓存
spring.thymeleaf.cache=false
3.无论是在dubbo还是在provider以及consumer的zookeeper配置中
所有的zookeeper集群无论是leader还是follower都可以配
eg:
zookeeper01是leader
dubbo-admin--把zookeeper的配置改为-->zookeeper01
zookeeper02是leader
dubbo-admin--把zookeeper的配置改为-->zookeeper01
因为最终无论配置是leader还是follower都会把请求转交给leader(除非leader宕机)
// 所有的zookeeper配置的端口号都应该是2181
因为dubbo中端口号就是2181 4.dubbo如何判定项目为服务生产者还是服务消费者?
是根据application.properties中所配置的dubbo.scan.base-packages属性来进行判定该项目是provider还是consumer 5.无论是provider还是consumer,service包必须要保持一致
provider-->IUserService:com.aaa.lee.dubbo.service
consumer-->IUserService:com.aaa.lee.dubbo.service
并且两个接口的名字也必须要保持一致!!!!
// 接口中方法也必须要保持一致(返回值名称,返回值类型,方法名,方法参数) 6.consumer项目中的controller需要调用service的时候,不能再使用@Autowired注解进行注入service
因为整个consumer项目中只有service的接口并没有实现类
// 需要使用dubbo所提供的@Reference 7.provider和consumer的application.properties配置文件中dubbo.application.name不能一样!!!!
provider:
dubbo.application.name=user-provider
consumer:
dubbo.application.name=user-consumer 8.无论是provider还是consumer项目都必须要把zookeeper的地址配置一致!!!
不要求必须配置leader--->follower会自动把请求转交给leader 9.所有的实体类必须要实现序列化接口
因为实现了序列化接口的实体类都可以把实体类以流的形式进行发送
provider会把User实体类转换为二进制流----->发送给consumer---->consumer所接收到的并不是一个User对象,而是一个二进制流
---->consumer必须要把整个二进制流转换为User对象才可以使用!
也就是说无论是consumer还是provider都必须要实现序列化接口
dubbo框架的使用方法。。。的更多相关文章
- dubbo框架提供Main方法运行容器的几种方式(转)
本文使用的是dubbo提供的主类com.alibaba.dubbo.container.Main启动容器. 主要区别是提供不同插件的的启动方式. 目录 一.项目内容 1.1.目录结构图 1.2 ...
- (转)dubbo框架基本分析
原文地址: https://my.oschina.net/zhengweishan/blog/698591 Dubbo架构基本分析 1. dubbo简单介绍 1.1 dubbo是什么 dubbo是一个 ...
- 基于Dubbo框架构建分布式服务(一)
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- 基于dubbo框架下的RPC通讯协议性能测试
一.前言 Dubbo RPC服务框架支持丰富的传输协议.序列化方式等通讯相关的配置和扩展.dubbo执行一次RPC请求的过程大致如下:消费者(Consumer)向注册中心(Registry)执行RPC ...
- 基于Dubbo框架构建分布式服务
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- [转载] 基于Dubbo框架构建分布式服务
转载自http://shiyanjun.cn/archives/1075.html Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务 ...
- Dubbo框架应用之(四)--Dubbo基于Zookeeper实现分布式实例
上三篇文章主要是解决了概念性的补充和学习,充分结合实战来深入理解 入门实例解析 第一:provider-提供服务和相应的接口 创建DemoService接口 package com.unj.dubbo ...
- 基于Dubbo框架构建分布式服务(集群容错&负载均衡)
Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...
- 性能测试二十九:Dubbo框架测试脚本编写
测试脚本编写 新建一个folder命名为lib,用于存放依赖包 把以下jar全部拷进lib下,并build path 找开发要 真正要测试的以jar包形式存在的代码的类, 打开看一下 放到lib并bu ...
随机推荐
- 小小明系列故事——游戏的烦恼(hdu 4517)
小小明系列故事--游戏的烦恼 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)To ...
- 网易云 微专业C++系统工程师
网易云 微专业C++系统工程师 一.学前基础 1.曾经学过某种编程语言(C语言最佳) 2.了解基本的变量.类型.作用域.循环和控制流程:了解基本数据类型(整数.浮点.字符串.数组等) 3.知道如何编译 ...
- PS8625替代方案CS5211|CS5211可以替代兼容PS8625方案|DP转LVDS芯片方案
PS8625|Parade普瑞 PS8625|Parade普瑞 PS8625芯片|Parade普瑞 PS8625方案|Parade普瑞 PS8625芯片代理|DP转LVDS|PS8625替代方案CS5 ...
- RTD2172方案|TYPEC转HDMI2.0转换器芯片|CS5265替代RTD2172
RTD2172 USB Type-C到HDMI转换器结合了USB Type-C输入接口和数字高清多媒体接口(HDMI)输出.嵌入式微控制器(MCU)基于工业标准8051内核.接收器端口将信道配置(CC ...
- Java初学者作业——编写Java程序,实现判断所输入字符的类型(数字、小写字母、大写字母或其他字符)
返回本章节 返回作业目录 需求说明: 编写Java程序,实现判断所输入字符的类型(数字.小写字母.大写字母或其他字符) 实现思路: 声明变量c,用于存储用户输入的字符. 通过Scanner接收用户输入 ...
- frontend-maven-plugin插件问题解决
1.插件介绍 frontend-maven-plugin为项目本地下载/安装Node和NPM,运行npm install命令 . 它适用于Windows,OS X和Linux. 这个插件也可以下载No ...
- javascript错误类型
ECMA-262 定义了下列 7 种错误类型,简单说明如下: Error:普通异常.通常与 throw 语句和 try/catch 语句一起使用. 利用属性 name 可以声明或了 解异常的类型,利用 ...
- SpringMVC拦截器的应用
一.作用 好文章参考:https://www.cnblogs.com/panxuejun/p/7715917.html 对请求进行预处理和后处理: 使用场景: 登录验证,判断用户是否登录 权限验证,判 ...
- 学习笔记--Java字面值
Java 字面值 /** * 关于字面值: * * - 字面值:10.100."abc"."a".true.false * * - 字面值就是数据 * * - ...
- sqlmap之--os-shell命令执行原理
最近也是在看sqlmap,感觉--os-shell这个命令确实很厉害,但我并不知道它的原理,所以来研究一下 环境 环境就是我本地搭的一个有sql注入漏洞的一个小demo 演示 这是我们的demo环境 ...