成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

拋出dubbo中的異常

Travis / 592人閱讀

摘要:以子模塊的方式搭建部分通常我們會定義一系列業(yè)務錯誤碼錯誤碼是放在還是好呢當然是放在好呢因為不用每次一修改業(yè)務錯誤碼就要更新版本但是又不能反過來依賴怎么辦呢增強里面有一個拋出異常增強用它來轉(zhuǎn)發(fā)一下和就行了加入依賴定義切面配置可以看到切面就

以maven子模塊的方式搭建

    cn.theviper
    dubbo-exception
    pom
    1.0

    
        api
        server
    

api部分

public class APIException extends RuntimeException implements Serializable{

    public int code;
    public String msg;

    public APIException(String msg) {
        super(msg);
    }

    public APIException(int code, String msg) {
        super(msg);
        this.code = code;
        this.msg = msg;
    }
    ...
}

通常我們會定義一系列業(yè)務錯誤碼

public enum APICode {

    OK(Integer.valueOf(0), "success"),
    PARAM_INVALID(4100, "parameter invalid");

    private int code;
    private String msg;

    APICode(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    getter setter...

}

錯誤碼是放在server還是api好呢?
當然是放在server好呢,因為不用每次一修改業(yè)務錯誤碼,就要更新api版本,但是api又不能反過來依賴server,怎么辦呢?

spring aop

spring aop增強里面有一個拋出異常增強,用它來轉(zhuǎn)發(fā)一下code和msg就行了

server加入依賴


    
        org.aspectj
        aspectjweaver
        1.8.9
    

server定義切面

@Component
@Aspect
public class ServiceExceptionInterceptor {

    private static final Logger logger = LoggerFactory.getLogger(ServiceExceptionInterceptor.class);

    @AfterThrowing(throwing="ex",pointcut="execution(* cn.theviper.service.**.*(..))")
    public APIResult handle(ServiceException ex){
        logger.info("intercept ServiceException:{}",ex.toString());
        throw new APIException(ex.getCode(),ex.getMsg());
    }

}

spring配置

可以看到,切面就是攔截了ServiceException,把ServiceException里面的code,msg又傳給APIException了

返回的結(jié)果

錯誤碼放在server帶來一個新的問題,api的返回結(jié)果往往會用到這個錯誤碼,怎么辦呢?
用繼承就好了

api

    APIResult register(RegisterForm form) throws APIException;
public class APIResult implements Serializable{

    public int code;
    public T data;
    public String msg;

    public APIResult() {
    }
    ...

}

server

public class ServerResult extends APIResult{

    public ServerResult() {
    }

    public ServerResult(APICode apiCode){
        this.code=apiCode.getCode();
        this.msg=apiCode.getMsg();
    }

    public ServerResult setData(T data){
        super.data=data;
        return this;
    }

}

返回的時候,直接

return new ServerResult(APICode.OK).setData("callback msg");

關(guān)于dubbo的異常分析,可以參見淺談dubbo的ExceptionFilter異常處理

下載

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66988.html

相關(guān)文章

  • Dubbo 自定義異常,你是怎么處理的?

    摘要:前言記錄對于自定義異常的處理方式實現(xiàn)目標服務層異常,直接向上層拋出,層統(tǒng)一捕獲處理如果是系統(tǒng)自定義異常,則返回其中對應為錯誤碼,對應為異常信息如果非系統(tǒng)自定義異常,返回未知錯誤,同時將異常堆棧信息輸出到日志便于定位問題項目架構(gòu)先來張系統(tǒng)架 showImg(https://segmentfault.com/img/remote/1460000017782781?w=768&h=506);...

    dingding199389 評論0 收藏0
  • Dubbo 源碼分析20 Dubbo服務提供者、服務消費者并發(fā)度控制機制

    摘要:代碼根據(jù)服務提供者和服務調(diào)用方法名,獲取。代碼根據(jù)服務提供者配置的最大并發(fā)度,創(chuàng)建該服務該方法對應的信號量對象。總結(jié)是控制消費端對單個服務提供者單個服務允許調(diào)用的最大并發(fā)度。 本文將詳細分析< dubbo:service executes=/>與< dubbo:reference actives = />的實現(xiàn)機制,深入探...

    不知名網(wǎng)友 評論0 收藏0
  • Dubbo 源碼分析 - 集群容錯之 Cluster

    摘要:集群用途是將多個服務提供者合并為一個,并將這個暴露給服務消費者。比如發(fā)請求,接受服務提供者返回的數(shù)據(jù)等。如果包含,表明對應的服務提供者可能因網(wǎng)絡原因未能成功提供服務。如果不包含,此時還需要進行可用性檢測,比如檢測服務提供者網(wǎng)絡連通性等。 1.簡介 為了避免單點故障,現(xiàn)在的應用至少會部署在兩臺服務器上。對于一些負載比較高的服務,會部署更多臺服務器。這樣,同一環(huán)境下的服務提供者數(shù)量會大于1...

    denson 評論0 收藏0
  • dubbo源碼解析(三十五)集群——cluster

    摘要:失敗安全,出現(xiàn)異常時,直接忽略。失敗自動恢復,在調(diào)用失敗后,返回一個空結(jié)果給服務提供者。源碼分析一該類實現(xiàn)了接口,是集群的抽象類。 集群——cluster 目標:介紹dubbo中集群容錯的幾種模式,介紹dubbo-cluster下support包的源碼。 前言 集群容錯還是很好理解的,就是當你調(diào)用失敗的時候所作出的措施。先來看看有哪些模式: showImg(https://segmen...

    gself 評論0 收藏0
  • Dubbo 源碼分析 - 服務導出

    摘要:支持兩種服務導出方式,分別延遲導出和立即導出。本文打算分析服務延遲導出過程,因此不會分析方法。服務導出之前,要進行對一系列的配置進行檢查,以及生成。返回時,表示需要延遲導出。賽程預告,下一站是服務導出的前置工作。 1.服務導出過程 本篇文章,我們來研究一下 Dubbo 導出服務的過程。Dubbo 服務導出過程始于 Spring 容器發(fā)布刷新事件,Dubbo 在接收到事件后,會立即執(zhí)行服...

    劉玉平 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<