http-dubbo

描述

http-dubbo 插件可以将 http 请求 encode 为 dubbo 协议转发给上游服务(注意:在 dubbo2.x 时上游服务的序列化类型必须是 fastjson)

属性

名称类型必选项默认值有效值描述
service_namestringdubbo 服务名
service_versionstring0.0.0dubbo 服务版本 默认 0.0.0
methodstringdubbo 服务方法名
params_type_descstringdubbo 服务方法签名描述,入参如果是 void 可不填写
serialization_header_keystring插件会读取该请求头判断 body 是否已经按照 dubbo 协议序列化完毕。如果该请求头的值为 true 则插件不会更改 body 内容,直接把他当作 dubbo 请求参数。如果为 false 则要求开发者按照 dubbo 泛化调用的格式传递参数,由插件进行序列化。注意:由于 lua 和 java 的插件序列化精度不同,可能会导致参数精度不同。
serializedbooleanfalse[true, false]serialization_header_key一样。优先级低于serialization_header_key
connect_timeoutnumber6000上游服务 tcp connect_timeout
read_timeoutnumber6000上游服务 tcp read_timeout
send_timeoutnumber6000上游服务 tcp send_timeout

启用插件

以下示例展示了如何在指定路由中启用 http-dubbo 插件:

http-dubbo - 图1note

您可以这样从 config.yaml 中获取 admin_key 并存入环境变量:

  1. admin_key=$(yq '.deployment.admin.admin_key[0].key' conf/config.yaml | sed 's/"//g')
  1. curl -i http://127.0.0.1:9180/apisix/admin/routes/1 \
  2. -H "X-API-KEY: $admin_key" -X PUT -d '
  3. {
  4. "uri": "/TestService/testMethod",
  5. "plugins": {
  6. "http-dubbo": {
  7. "method": "testMethod",
  8. "params_type_desc": "Ljava/lang/Long;Ljava/lang/Integer;",
  9. "serialized": true,
  10. "service_name": "com.xxx.xxx.TestService",
  11. "service_version": "0.0.0"
  12. }
  13. },
  14. "upstream": {
  15. "type": "roundrobin",
  16. "nodes": {
  17. "127.0.0.1:1980": 1
  18. }
  19. }
  20. }'

测试插件

通过上述命令启用插件后,可以使用如下命令测试插件是否启用成功:

  1. curl --location 'http://127.0.0.1:9080/TestService/testMethod' \
  2. --data '1
  3. 2'

如何获取 params_type_desc

  1. Method[] declaredMethods = YourService.class.getDeclaredMethods();
  2. String params_type_desc = ReflectUtils.getDesc(Arrays.stream(declaredMethods).filter(it->it.getName().equals("yourmethod")).findAny().get().getParameterTypes());
  3. //方法重载情况下需要找自己需要暴露的方法 ReflectUtils 为 dubbo 实现

如何按照 dubbo 协议使用 json 进行序列化

为了防止精度丢失。我们推荐使用序列化好的 body 进行请求。 dubbo 的 fastjson 序列化规则如下:

  • 每个参数之间使用 toJSONString 转化为 JSON 字符串

  • 每个参数之间使用换行符 \n 分隔

部分语言和库在字符串或数字调用 toJSONString 后结果是不变的这可能需要你手动处理一些特殊情况例如:

  • 字符串 abc" 需要被 encode 为 "abc\""

  • 字符串 123 需要被 encode 为 "123"

抽象类,父类或者泛型作为入参签名,入参需要具体类型时。序列化需要写入具体的类型信息具体参考 WriteClassName

删除插件

当你需要禁用 http-dubbo 插件时,可以通过以下命令删除相应的 JSON 配置,APISIX 将会自动重新加载相关配置,无需重启服务。