限流规则和回调函数都设定到了自己的服务端,当有其它服务调用我服务接口且达到了限流规则设定的阀值,返回给调用方的信息是这样的:Caused by: com.alibaba.dubbo.remoting.RemotingException: com.alibaba.com.caucho.hessian.io.HessianProtocolException: expected map/object at java.lang.String ({"code":"120023","message":"QPS exceeded the threshold set by Sentinel"})
回调函数定制信息如下: DubboFallbackRegistry.setProviderFallback(new DubboFallbackImpl4Producer());
public class DubboFallbackImpl4Producer implements DubboFallback { @OverRide public Result handle(Invoker<?> invoker, Invocation invocation, BlockException ex) { StringBuffer sb = new StringBuffer(); sb.append(invoker.getInterface().toString()); Map<String, String> map = new HashMap<>(2); map.put("code", "120023"); map.put("message", "QPS exceeded the threshold set by Sentinel : " + sb); return new RpcResult(new JSONObject(map).toString()); } }
原提问者GitHub用户Mr-ZhangJ
HessianProtocolException似乎是Dubbo RPC调用中的反序列化出错。 检查dubbo和fastjson版本在提供者和使用者端是否相同。
Map<String, String> map = new HashMap<>(2); ... return new RpcResult(new JSONObject(map).toString());
您的项目中的JSONObject包是什么? fastjson中JSONObect的构造函数是: JSONObject(映射<字符串,对象>映射),而不是JSONObject。
原回答者GitHub用户cdfive
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。