1.Dubbo 常见错误及解决方法
1.Dubbo 常见错误及解决方法
地址找不到:No provider available 找不到服务,这时候可能有这么几种情况: Provider 服务没启动,或者注册中心Nacos宕机了。 Dubbo 的服务配置有误差,必须保证服务名,组别(默认是 Dubbo ),version 三者都正确。 排查: 访问注册中心的 Ops 系统,查询对应的服务是否有提供者列表;同时检查调用者应用所在服务器的日志(一般每种注册服务的客户端都会有对应的日志记录),查看是否有地址信息的推送/拉取记录。 如无,则表明发布者发布服务失败,检查发布者的应用启动是否成功。
如有服务,则检查调用者应用所连接的注册中心,确认跟预期的环境要匹配。
调用超时:client-side timeout 一般超时是调用端发生在请求发出后,无法在指定的时间内获得对应的响应。原因大概有以下几种情况: 服务端确实处理比较慢,无法在指定的时间返回结果,调用端就自动返回一个超时的异常响应来结束此次调用。 服务端如果响应的比较快,但当客户端 负载很高,负载压力很大的时候,会因为客户端请求发不出去、响应卡在 TCP Buffer 等问题,造成超时。因为客户端接收到服务端发来的数据或者请求服务端的数据,都会在系统层面排队,如果系统负载比较高,在内核态的时间占比就会加长,从而造成客户端获取到值时已经超时。 排查 在调用超时的方法代码逻辑里加入时间逻辑:
long start = System.currentTimeMillis();
//逻辑代码
long end = System.currentTimeMillis();
log.info("文件上传调用时间是{}",end-start);
这样就可以查看当前超时方法的调用时间了,分析Dubbo调用超时的原因,根据业务的实际调用时间在代码中设置timeout时间。当然也有可能是网络状况的原因导致超时。 序列化失败:HessianRuntimeException 排查: 检查方法的入参是否实现 Serializable 接口。 检查服务方法的传入传出参数是否继承了 Number、Date、ArrayList、HashMap 等 Hessian 特殊化处理的类。
2.Java断言
语法1:assert expression; //expression代表一个布尔类型的表达式,如果为真,就继续正常运行,如果为假,程序退出 语法2:assert expression1 : expression2;
//expression1是一个布尔表达式,expression2是一个基本类型或者Object类型,如果expression1为真,则程序忽略expression2继续运行;如果expression1为假,则运行expression2,然后退出程序。
assertEquals(true, StringUtils.isEmpty(user.getName));
第一个参数是true,就是断言的期望值,看逗号后边的另一个参数的结果,如果结果为true,就是期望值,返回期望值。
assertNotNull(name);
判断参数是否不为空,如果name为空,在这行跳出执行。
如果name不为空,则继续执行代码。
断言可以配合枚举类使用。 断言可以检查运行结果。 断言失败时会抛出 AssertionError,导致程序结束退出。因此,断言不能用于可恢复的程序错误。 虽然断言返回的是 boolean 值,但是并不能将其作为条件判断语句。
- 如何打击“假货、高仿”类小程序
- centos 6x系统下源码安装mysql操作记录
- 【3】利用Word模板生成文档的总结
- 【2】快速代码集的由来及概览
- silverlight数据绑定模式TwoWay,OneWay,OneTime的研究
- Silverlight数据绑定/IValueConverter学习笔记
- silverlight:DeepZoom版的图片局部放大效果
- Linq之ToDictionary<TSource, TKey, TElement>的写法
- vs.net的调试小技巧之#define debug(适合新手)
- byte[]数组下标的最大值
- silverlight图片局部放大效果
- 局域网与互联网环境下MTU的快速确定方法
- 【4】通过简化的正则表达式处理字符串
- silverlight中的socket编程注意事项
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法