如何保证一个组合结构的接口逻辑单个异常不回影响整体,求推荐好的实践 - V2EX
lnanddj
V2EX    Java

如何保证一个组合结构的接口逻辑单个异常不回影响整体,求推荐好的实践

  •  
  •   lnanddj Jun 24, 2020 2313 views
    This topic created in 2172 days ago, the information mentioned may be changed or developed.

    常见的架构,API 接入层上需要将多个数据源组合吐出。前面获取的数据,是后面的依赖。

    有没有一种比较优雅点的方式,可以避免某个小功能点的代码 /数据异常导致的异常导致整体数据无法吐出。

    针对每个功能点 try...catch... 确实不太优雅,也难以维护。

    全局的异常捕获也无法完成这样的需求。

    各位大佬,有没有自己的实践可以分享一下的?

    6 replies    2020-06-25 21:04:29 +08:00
    lnanddj
        1
    lnanddj  
    OP
       Jun 24, 2020
    自己实现类似 FilterChain 的东西,然后针对 chain 的调用做 try...catch.. 貌似也可以,但是对于前后依赖的数据有点蛋疼
    ldcloli
        2
    ldcloli  
       Jun 24, 2020
    将每个功能点拆出来成一个单独任务,可以设置每个任务的前后依赖,设置返回数据的必要性,最后所有依赖的任务排列成有向无环图,并行执行
    momocraft
        3
    momocraft  
       Jun 24, 2020
    Future / Either
    crclz
        4
    crclz  
       Jun 25, 2020
    前面的数据是后面的依赖...你前面数据都获取失败了,后面数据怎么获取?

    对于每一个环节,尝试向数据源读取 3 次,如果 3 次失败,就抛出异常。

    正常情况下是不会出现失败的,如果失败很多次,就报警发邮箱。
    lnanddj
        5
    lnanddj  
    OP
       Jun 25, 2020
    @crclz 只有最前面的数据核心数据是,后面有大批的组合逻辑,这个逻辑相对独立。需求核心是,保障核心数据安全。
    重试是不适合的,1. 性能不允许(支持单机 1w 的 QPS ) 2. 有时候错误的数据或者代码的异常重试无法解决。
    lnanddj
        6
    lnanddj  
    OP
       Jun 25, 2020
    @ldcloli 嗯,方案可以考虑一下
    About     Help     Advertise     Blog     API     FAQ     Solana     989 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 30ms UTC 18:56 PVG 02:56 LAX 11:56 JFK 14:56
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86