Dubbo之高级特性
Dubbo
- 注意
当启动服务时,该服务会占用本机一个端口号,故在一台电脑启动多个服务时需要在配置文件中更占用本机的端口号
<!--服务占用本机的端口-当本机启动多个服务时须保持不同-->
<dubbo:protocol port=""/>
<!--dubbo的配置-->
<!--1.配置项目的名称,唯一-->
<dubbo:application name="dubbo-service"/>
<!--2.配置注册中心的地址-->
<dubbo:registry address="zookeeper://192.168.23.129:2181" timeout="250000"/>
<!--3.配置dubbo包扫描,注解注册服务-->
<!-- <dubbo:annotation package="com.yh1.impl" />-->
<!--3.2xml配置方式注册服务,类上不需要注解-->
<dubbo:service interface="com.yh.ours.UserService" ref="demoService"/>
<bean id="demoService" class="com.yh1.impl.UserServiceImpl"/>
序列化
查询出数据后返回给消费者时所执行的便是序列化
- 作用:用于不同机器间传输对象的转换,将对象序列化为 流数据进行传输
- 被序列化的对象类必须实现序列化接口Serializable
- 接受到流数据后,反序列化为java对象
- 序列化和反序列化两者皆需要用到对象类,故定义在一个独立模块中,让两者依赖它—>类似于公共接口模块
- 即domain/pojo实体类皆需要实现接口Serializable且放在独立模块来作为资源被依赖
<groupId>org.yh</groupId>
<artifactId>debbo-interface</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<!--被依赖资源-->
<dependency>
<groupId>org.yh</groupId>
<artifactId>dubbo-pojo</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>

序列化和反序列化操作dubbo已经封装好,只需让pojo类实现接口即可
eg:
//必须实现Serializable
//一个实体类用于 模仿序列化和反序列化操作
public class User implements Serializable {
int id;
String name;
public User() {
}
public User(int id, String name) {
this.id = id;
this.name = name;
}
//省略get和set方法
Cotroller代码
@RequestMapping("/find.do")
public User find(int id){
return userService.findById(id);
}

地址缓存
问:注册中心挂了,服务是否可以正常访问?
答:可以,当第一次访问后,会将服务地址缓存至本地
但是当服务的地址变了以后就不行了,需要重新访问注册中心获取
超时和重试
超时
问:消费者创建线程调用提供者服务,如果调用失败或者提供者查询时间过长或挂了,则消费者将一直等待
- 可以在服务者方法中使用线程沉睡来模拟上述情况
@Service
public class UserServiceImpl implements UserService {
@Override
public User findById(int id) {
//此处让服务睡5秒,用来演示超时操作
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
User user=new User(1,"jack");
return user;
}
}
解决:设置timeout属性值来控制超时时间
- 在消费方@reference注解中设置
- 在提供者@service注解中设置
- 在配置文件中配置
<!--2.配置注册中心的地址-->
<dubbo:registry address="zookeeper://192.168.23.129:2181" timeout="250000"/>
- 建议配置在服务提供方@Service上
- 超时时消费者报错如下

重试
问题:出现了网络抖动网突然断了一下,断了3s超时时间设置是1s,则这一次请求就会失败,则会重新发送请求,一共发送3次
解决1:通过retries属性类设置重试次数。默认为2
多版本
灰度发布:新功能时,让一部分用户使用新版本,稳定后让全部用户使用新的版本。

使用:使用version属性来设置和调用同一个接口的不同版本
eg:公共接口模块中的UserService接口在服务提供者中有俩实现类UserServiceImpl1和UserServiceImpl2
在服务提供者的UserServiceImpl1@Service(version=“v1.0”)中设置version和UserServiceImpl2@Service(version=“v2.0”)
在消费者的@Reference(version=“v1.0 or v2.0”)中设置version来选择使用哪个版本
注:此处检验失败,原因未知
负载均衡
适用于集群环境,相同的服务部署在多台机器上
模拟步骤:
1.在服务提供者的@Service注解中添加weight属性,配置权重(可在服务内打印一句话来区别不同的服务)
2.启动该服务tomcat7:run
3.更改三个端口号后继续1,2,3步骤,直至启动三个服务器为止,保持权重不同
4.在消费者的@reference注解中配置loadbalance属性(共有四个值下面有)
5.启动服务,开始模拟
- 负载均衡策略(4种):来解决访问哪个机器
可以更改同一个服务的tomcat,dubbo的qos,本机三个的端口来模拟同一服务部署在多台机器
1.
<!--tomcat插件-->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.1</version>
<configuration>
<port>8000</port>
<path>/</path>
</configuration>
</plugin>
2.
<dubbo:protocol port="20881"/>
3.
<!--dubbo的配置-->
<!--1.配置项目的名称,唯一-->
<dubbo:application name="dubbo-service">
<!--dubbo的pos服务一个服务会启动一次,故一台机器时不同服务需要更改-->
<dubbo:parameter key="qos.port" value="33331"/>
</dubbo:application>
- 权重weight是服务提供者@Service注解的配置属性
- Random按权重weight属性随机。按权重设置随机概率
- RoundRobin按权重轮询
- LeastActice最少活跃调用数,相同则随机–>使用机器中处理请求最快的的机器
- ConsisitentHash:一致性Hash,相同参数的请求总是发到同一提供者

- 在消费者的@Reference注解中使用loadbalance属性(该属性值为loadbalance抽象类的四种实现类属性即上的小写)来设置采用上述哪种负载均衡策略

集群容错
问题: 消费者调用集群中某一机器出错了,该如何处理?
- 集群容错模式:
- **Failover Cluster:**失败重试。默认值。当出现失败,重试其它服务器,默认重试2次,使用retries配置。–一般用于读操作
- **Failfast Cluster
Dubbo之高级特性的更多相关文章
- Dubbo高级特性实践-泛化调用
引言 当后端Java服务用Dubbo协议作为RPC方案的基础,但部分消费方是前端Restful的PHP服务,不能直接调用,于是在中间架设了Router服务提供统一的基于HTTP的后端调用入口. 而Ro ...
- Dubbo 高级特性实践-泛化调用
引言 当后端Java服务用Dubbo协议作为RPC方案的基础,但部分消费方是前端Restful的PHP服务,不能直接调用,于是在中间架设了Router服务提供统一的基于HTTP的后端调用入口. 而Ro ...
- ActiveMQ中的Destination高级特性(一)
---------------------------------------------------------------------------------------- Destination ...
- Python3学习(二)-递归函数、高级特性、切片
##import sys ##sys.setrecursionlimit(1000) ###关键字参数(**关键字参数名) ###与可变参数不同的是,关键字参数可以在调用函数时,传入带有参数名的参数, ...
- 云端卫士实战录 | Java高级特性之多线程
<实战录>导语 一转眼作为一名Java开发者已经四年多时间了,说长不长说短不短,对于java的感情还是比较深的,主要嘛毕竟它给了我饭吃.哈哈,开个玩笑.今天我想借此机会来和大家聊聊Java ...
- javascript高级特性
01_javascript相关内容02_函数_Arguments对象03_函数_变量的作用域04_函数_特殊函数05_闭包_作用域链&闭包06_闭包_循环中的闭包07_对象_定义普通对象08_ ...
- Visual Studio 2015 速递(4)——高级特性之移动开发
系列文章 Visual Studio 2015速递(1)——C#6.0新特性怎么用 Visual Studio 2015速递(2)——提升效率和质量(VS2015核心竞争力) Visual Studi ...
- Android TextView高级特性使用
TextView一般都是用来显示一段文本,这里说的高级特性主要是一些我们平常不太常用的属性.包括文字阴影.自定义字体.html嵌入多格式.字体加粗.插入图片.这些特性平时开发APP的时候,可能一般使用 ...
- Python的高级特性8:你真的了解类,对象,实例,方法吗
Python的高级特性1-7系列是本人从Python2过渡3时写下的一些个人见解(不敢说一定对),接下来的系列主要会以类级为主. 类,对象,实例,方法是几个面向对象的几个基本概念,其实我觉得很多人并不 ...
随机推荐
- Java安全之jar包调试技巧
Java安全之jar包调试技巧 调试程序 首先还是创建一个工程,将jar包导入进来 调试模式的参数 启动中需要加入特定参数才能使用debug模式,并且需要开放调试端口 JDK5-8: -agentli ...
- 牛客练习赛53 E-老瞎眼pk小鲜肉(思维+线段树+离线)
前言 听说是线段树离线查询?? 做题做着做着慢慢对离线操作有点感觉了,不过也还没参透,等再做些题目再来讨论离线.在线操作. 这题赛后看代码发现有人用的树状数组,$tql$.当然能用树状数组写的线段树也 ...
- JavaScript——DOMM
文本节点 != 文本内容
- Hyper-V安装CentOS修改分辨率
grubby --update-kernel=ALL --args="video=hyperv_fb:1600x900" reboot https://blog.csdn.net/ ...
- 手把手教你通过SQL注入盗取数据库信息
目录 数据库结构 注入示例 判断共有多少字段 判断字段显示位置 显示出登录用户和数据库名 查看所有数据库 获取对应数据库的表 获取对应表的字段名称 获取用户密码 SQL注入(SQL Injection ...
- Kubernets二进制安装(5)之私有仓库harbor搭建
在IP地址为192.168.80.50,机器名为mfyxw50上搭建私有仓库harbor harbor下载地址: harbor下载连接地址:https://github.com/goharbor/ha ...
- Cron表达式在 定时执行专家 5.0 中的使用方式
在<定时执行专家 V5.0>程序内部使用了包含 6 位的 Cron表达式,第一个字段(second)没有使用.程序内部一直 second 位是 0.在 Cron表达式的界面上可以设置 5位 ...
- IDEA 安装常用操作二
一.IDEA启动慢,因为启动时编译.缓存.创建索引等,如果断电等启动异常,可以让缓存索引失效 迁移IDEAD时,可以找到config.system等文件夹, 随着时间使用越久,空间占用越大,另外觉得浪 ...
- 牛客多校第五场B generator1(十进制矩阵快速幂)题解
题意: 已知 \(X_i = a * X_{i - 1} + b * X_{i - 2}\),现给定\(X_0,X_1,a,b\),询问\(X^n \mod p\),其中\(n <= 10^{1 ...
- 手工数据结构系列-C语言模拟队列和栈 hdu1702
#include <stdio.h> #include <stdlib.h> //================= DATA STRUCTURE ============== ...
- Dubbo高级特性实践-泛化调用