码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Dubbo Data length too large与流式调用


    Payload过大

    今天有个业务反馈调用接口报错了,后来经过排查,发现是因为调用dubbo时响应的payload超过了限制

    在这里插入图片描述
    这是个分页到es查询的接口,参数很简单
    在这里插入图片描述
    但是由于索引中字段content是一个长字符串,参数中的size比较大,导致触发了dubbo payload的限制
    在这里插入图片描述
    后来查询服务日志,发现了很多类似的错误

    在这里插入图片描述

    其实这个接口限制单次查询的最大条数是500,但是因为该业务的单条数据比较大,导致300就已经触发限制了。

    在接口交互时,参数的选择,要结合自身的数据特征

    如何解决?流式调用

    对于这类比较大的数据传输,其实可以考虑使用支持流式传输的方式,将大的参数或响应,拆分为多个,一次调用多次响应,one request - multi response,server-side streaming
    dubbo3,GRPC,RSocket都支持流式的交互方式

    GRPC

    GRPC

    • 服务端流式响应
    • 客户端流式调用
    • 双向流
      在这里插入图片描述

    RSocket

    RSocket交互模型中的

    • Request/Response(Single-response):支持常见的一个请求一个响应,也支持多个请求,一个响应,即客户端流式调用
    • Request/Stream (multi-response, finite):服务端流式
    • channel:双向流式

    在这里插入图片描述

    Dubbo

    dubbo 2.x并不支持流式调用,dubbo3.0支持,但是3.0也是刚刚发布不就,前段时间看issues看到了一些关于流式调用的问题,因此可能还不太稳定,小心使用吧

    Triple协议介绍
    Triple Streaming 通信模式

    riple协议SERVER_STREAM模式下,通过StreamObserver响应数据时,不能实时发送给客户端,而只能等到整个方法执行完后一起发

    流式调用实现demo

    因之前也碰到过类似的问题, 有同学使用dubbo接口传输图片,也触发了payload的限制,因此当时也调研了一些支持流式调用的RPC,自己也写了个demo

    https://github.com/lanicc/mini-rpc

  • 相关阅读:
    Rust语言——小小白的入门学习05
    萃取和constexpr
    6.紧耦合和松耦合有什么区别?
    论文中常见的拟合散点验证图(R语言版)
    机器学习极值问题
    印刷企业使用数字工厂管理系统前后有什么变化
    第十二章·装饰模式
    洛谷 P1075 [NOIP2012 普及组] 质因数分解
    中小企业如何选择进销存软件?
    论文综述的重要性及写作
  • 原文地址:https://blog.csdn.net/qq_26824159/article/details/126664145
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号