经验积累-错误记录-dubbo接口调用大小限制
异常信息
Caused by: java.io.IOException: Data length too large: 8390726, max payload: 8388608, channel: NettyChannel [channel=[id: 0xd6e137da, /192.168.16.126:52084 => /10.101.0.107:30000]]
关于dubbo接口调用大小限制
1. dubbo接口限制, 针对的是单个参数, 还是整体参数的大小呢?
1. 经过测试,大小限制针对整体参数大小.
2. 如何解决?
1. dubbo默认参数大小限制为8388608(8M).
2. 可以通过配置修改
3. 配置payload属性:dubbo.protocol.dubbo.payload=10485760
3. 另外一种方式:绕过dubbo的限制
大文件,都统一用第三方文件系统存储,dubbo接口调用中,只传递url地址.
测试代码
String fileName = System.getProperty("user.home")+"/Downloads/migrate-local-repo-tool.jar";
try(FileInputStream fis = new FileInputStream(fileName);
ByteArrayOutputStream baos = new ByteArrayOutputStream()){
int length;
byte[] buf = new byte[4096];
while((length = fis.read(buf)) != -1){
baos.write(buf,0,length);
}
String imgBase64 = Base64Utils.encodeToString(baos.toByteArray());
if( 8388608 < imgBase64.length() ){// dubbo接口数据大小限制1024 * 1024 * 8=8388608
imgBase64 = imgBase64.substring(0,8388608);
}
DemoResult demo = demoService.doOcr(imgBase64,'demo');
assertNotNull(demo);
System.out.println(new Gson().toJson(demo));
} catch(Exception e){
log.error("{}",e);
}