Skip to main content
Version: 3.11

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 插件:

note

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

admin_key=$(yq '.deployment.admin.admin_key[0].key' conf/config.yaml | sed 's/"//g')
curl -i http://127.0.0.1:9180/apisix/admin/routes/1  \
-H "X-API-KEY: $admin_key" -X PUT -d '
{
"uri": "/TestService/testMethod",
"plugins": {
"http-dubbo": {
"method": "testMethod",
"params_type_desc": "Ljava/lang/Long;Ljava/lang/Integer;",
"serialized": true,
"service_name": "com.xxx.xxx.TestService",
"service_version": "0.0.0"
}
},
"upstream": {
"type": "roundrobin",
"nodes": {
"127.0.0.1:1980": 1
}
}
}'

测试插件#

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

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

如何获取 params_type_desc#

Method[] declaredMethods = YourService.class.getDeclaredMethods();
String params_type_desc = ReflectUtils.getDesc(Arrays.stream(declaredMethods).filter(it->it.getName().equals("yourmethod")).findAny().get().getParameterTypes());

//方法重载情况下需要找自己需要暴露的方法 ReflectUtils 为 dubbo 实现

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

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

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

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

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

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

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

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

删除插件#

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