gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

在微服務架構中異常如何正確使用

本篇文章給大家介紹一下在微服務架構中異常正確使用的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

在微服務架構中異常如何正確使用

異常的正確使用在微服務架構中的重要性排前三,沒什么意見吧

異常的正確使用在微服務架構中的重要性排前三,沒什么意見吧

Curdboy 們好久不見,先祝大家端午節快樂。最近想說說異常,我的思考儼然形成了閉環,希望這套組合拳能對你的業務代碼有所幫助。

下面只討論世界上最好的語言和生態最完整的語言,沒什么意見吧。

異常的異同

PHP 在 PHP7 異常的設計和 Java 保持一致了 Exception extends Throwable ,不過在歷史原因和設計理念上還是有一些細微的差別。比如 PHP 中的異常是有 code 屬性的,這樣就存在多種異常聚類為同一個異常,然后在catch 區塊里根據 code 寫不同的業務邏輯代碼。

而 Java 異常則沒有code ,不能這樣設計,只能針對不同的情況使用不同的異常。所以我們習慣服務對外暴露的通過包裝類來封裝,而不是直接依賴異常的透傳。

統一異常的處理

在 Java 代碼里,最讓人詬病的就是漫山遍野的try catch ,沒什么意見吧。隨便抓一段代碼

@Override public DataResult<List<AdsDTO>> getAds(Integer liveId) {          try {         List<AdsDTO> adsDTO = new ArrayList<>();         //...業務邏輯省略         DataResult.success(adsDTO);     } catch (Exception e) {         log.error("getAds has Exception:{}", e.getMessage(), e);         DataResult.failure(ResultCode.CODE_INTERNAL_ERROR, e.getMessage()); // 將異常信息返回給服務端調用方     }          return dataResult; }

很多時候都是無腦上來就先寫個 try catch 再說,不管里面是否會有非運行時異常。比較好的方式是使用 aop 的方式來攔截所有的服務方法的調用,統一接管異常然后做處理。

@Around("recordLog()") public Object record(ProceedingJoinPoint joinPoint) throws Throwable {   //... 請求調用來源記錄      Object result;    try {     result = joinPoint.proceed(joinPoint.getArgs());   } catch (Exception e) {     //... 記錄異常日志          DataResult<Object> res = DataResult.failure(ResultCode.CODE_INTERNAL_ERROR, e.getMessage());     result = res;   }      //... 返回值日志記錄      return result; }

有一點小問題,如果直接將 A 服務的異常信息直接返回給調用者 B,可能存在一些潛在的風險,永遠不能相信調用者,即使他根正苗紅三代貧農也不行。因為不能確定調用者會將該錯誤信息作何處理,可能就直接作為 json 返回給了前端。

RuntimeException

在 Java 中異常可以分為運行時異常和非運行時異常,運行時異常是不需要捕獲的,在方法上也不需要標注 throw Exception,比如我們在方法里使用 guava 包里的Preconditions工具類,拋出的IllegalArgumentException也是運行時異常。

@Override public DataResult<List<AdsDTO>> getAds(Integer liveId) {   Preconditions.checkArgument(null != liveId, "liveIds not be null");      List<AdsDTO> adsDTOS = new ArrayList<>();   //...業務邏輯省略   return DataResult.success(adsDTOS); }

我們也可以使用該特性,自定義自己的業務異常類繼承RuntimeException

XXServiceRuntimeException extends RuntimeException

對于不符合業務邏輯情況則直接拋出 XXServiceRuntimeException

@Override public DataResult<List<AdsDTO>> getAds(Integer liveId) {    if (null == liveId) {     throw new XXServiceRuntimeException("liveId can't be null");   }      List<AdsDTO> adsDTOS = new ArrayList<>();   //...業務邏輯省略   return DataResult.success(adsDTOS); }

然后在 aop 做統一處理做相應的優化,對于前面比較粗暴的做法,應該將除了XXServiceRuntimeException和IllegalArgumentException之外的異常內部記錄,不再對外暴露,但是一定要記得通過requestId將分布式鏈路串起來,在DataResult中返回,方便問題的排查。

@Around("recordLog()") public Object record(ProceedingJoinPoint joinPoint) throws Throwable {   //... 請求調用來源記錄      Object result;    try {     result = joinPoint.proceed(joinPoint.getArgs());   } catch (Exception e) {     //... 記錄異常日志①     log.error("{}#{}, exception:{}:", clazzSimpleName, methodName, e.getClass().getSimpleName(), e);          DataResult<Object> res = DataResult.failure(ResultCode.CODE_INTERNAL_ERROR);     if (e instanceof XXServiceRuntimeException || e instanceof IllegalArgumentException) {        res.setMessage(e.getMessage());     }       result = res;   }    if (result instanceof DataResult) {       ((DataResult) result).setRequestId(EagleEye.getTraceId()); // DMC    }      //... 返回值日志記錄      return result; }

異常監控

說好的閉環呢,使用了自定義異常類之后,對異常日志的監控報警的閾值就可以降低不少,報警更加精準,以阿里云 SLS 的監控為例

* and ERROR not XXServiceRuntimeException not IllegalArgumentException|SELECT COUNT(*) AS count

這里監控的是記錄異常日志① 的日志

PHP 里的異常

上面 Java 里說到的問題在 PHP 里也同樣存在,不用 3 種方法來模擬 aop 都不能體現 PHP 是世界上最好的語言

//1. call_user_func_array //2. 反射 //3. 直接 new try {   $class = new $className();   $result = $class->$methodName(); } catch (Throwable $e) {     //...略 }

類似上面的架構邏輯不再重復編寫偽代碼,基本保持一致。也是自定義自己的業務異常類繼承RuntimeException,然后做對外輸出處理。

但是PHP 里有一些歷史包袱,起初設計的時候很多運行時異常都是作為 Notice,Warning 錯誤輸出的,但是錯誤的輸出缺少調用棧,不利于問題的排查

function foo(){   return boo("xxx"); }  function boo($a){   return explode($a); }  foo();
Warning: explode() expects at least 2 parameters, 1 given in /Users/mengkang/Downloads/ab.php on line 8

看不到具體的參數,也看不到調用棧。如果使用set_error_handler + ErrorException之后,就非常清晰了。

set_error_handler(function ($severity, $message, $file, $line) {     throw new ErrorException($message, 10001, $severity, $file, $line); });  function foo(){   return boo("xxx"); }  function boo($a){   return explode($a); }  try{   foo(); }catch(Exception $e){   echo $e->getTraceAsString(); }

最后打印出來的信息就是

Fatal error: Uncaught ErrorException: explode() expects at least 2 parameters, 1 given in /Users/mengkang/Downloads/ab.php:12 Stack trace: #0 [internal function]: {closure}(2, 'explode() expec...', '/Users/mengkang...', 12, Array) #1 /Users/mengkang/Downloads/ab.php(12): explode('xxx') #2 /Users/mengkang/Downloads/ab.php(8): boo('xxx') #3 /Users/mengkang/Downloads/ab.php(15): foo() #4 {main}   thrown in /Users/mengkang/Downloads/ab.php on line 12

修改上面的函數

function boo(array $a){   return implode(",", $a); }

則沒法捕獲了,因為拋出的是PHP Fatal error: Uncaught TypeError,PHP7 新增了
class Error implements Throwable,則在 PHP 系統錯誤日志里會有 Stack,但是不能和整個業務系統串聯起來,這里就又不得不說日志的設計,我們期望像 Java 那樣通過一個 traceId 將所有的日志串聯起來,從 Nginx 日志到 PHP 里的正常 info level 日志以及這些Uncaught TypeError,所以接管默認輸出到系統錯誤日志,在 catch 代碼塊中記錄到統一的地方。那么這里就簡單修改為

set_error_handler(function ($severity, $message, $file, $line) {     throw new ErrorException($message, 10001, $severity, $file, $line); });  function foo(){   return boo("xxx"); }  function boo(array $a){   return implode(",", $a); }  try{   foo(); }catch(Throwable $e){   echo $e->getTraceAsString(); }

catch Throwable就能接受Error和Exception了。

但是 set_error_handler 沒辦法處理一些錯誤,比如E_PARSE的錯誤,可以用register_shutdown_function來兜底。

值得注意的是register_shutdown_function的用意是在腳本正常退出或顯示調用exit時,執行注冊的函數。
是腳本運行(run-time not parse-time)出錯退出時,才能使用。如果在調用register_shutdown_function的同一文件的里面有語法錯誤,是無法注冊的,但是我們項目一般都是分多個文件的,這樣就其他文件里有語法錯誤,也能捕獲了

register_shutdown_function(function(){     $e = error_get_last();     if ($e){         throw new ErrorException($e["message"], 10002, E_ERROR, $e["file"], $e["line"]);     } });

如果你想直接使用這些代碼(PHP的)直接到項目可能會有很多坑,因為我們習慣了系統中有很多 notice 了,可以將 notice 的錯誤轉成異常之后主動記錄,但是不對外拋出異常即可。

推薦學習:php視頻教程

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
成年人网站大全| 欧美日韩亚洲一| 91日韩视频在线观看| 日韩av在线第一页| 欧美不卡在线播放| 国产精品宾馆在线精品酒店| 国产中文字幕二区| 日韩精品视频久久| 日韩免费毛片视频| 一本久道综合色婷婷五月| 国产欧美高清在线| 国产九九在线观看| 香蕉精品视频在线| 日本一级黄视频| 日韩免费视频播放| 日本美女高潮视频| 超碰在线资源站| 国产玉足脚交久久欧美| 国产xxxxx在线观看| 污污的网站18| 中文字幕精品在线播放| 欧美成人高潮一二区在线看| 男女av免费观看| 欧美激情国内自拍| 隔壁人妻偷人bd中字| 人妻内射一区二区在线视频| 国产aⅴ爽av久久久久| www.日本在线视频| 手机看片福利日韩| 喜爱夜蒲2在线| 欧美日韩亚洲一二三| 麻豆md0077饥渴少妇| aaa毛片在线观看| 日本美女久久久| 99热成人精品热久久66| 国产精品久久成人免费观看| 午夜精品久久久内射近拍高清| 污视频网址在线观看| 亚洲熟妇无码一区二区三区| 9l视频白拍9色9l视频| 国产精品视频一二三四区| 美女一区二区三区视频| 91.com在线| 一级全黄肉体裸体全过程| 爱福利视频一区二区| 日韩视频 中文字幕| 欧美国产日韩另类 | 国产成人无码精品久久久性色| 91pony九色| 欧美伦理视频在线观看| 欧美午夜小视频| 久久精品一二三四| www.se五月| 91蝌蚪视频在线观看| 免费在线观看的av网站| 国产美女在线一区| 国产91沈先生在线播放| 国产经典久久久| 欧美aaa在线观看| 午夜免费一级片| 亚洲精品在线视频播放| www.国产视频.com| 国产精品区在线| 国产欧美一区二| 日韩av片免费观看| 毛片毛片毛片毛| 99re精彩视频| av在线网址导航| 日韩av影视大全| 亚洲区成人777777精品| 污污污污污污www网站免费| 免费成人深夜夜行网站视频| 青少年xxxxx性开放hg| 日韩视频一二三| 午夜精品久久久久久久无码| 成人av在线不卡| 国产又大又硬又粗| 色一情一乱一伦一区二区三区日本| 污污视频网站免费观看| 国产福利在线免费| 福利网在线观看| 一本久道高清无码视频| 青青草原av在线播放| 亚洲这里只有精品| 日本国产中文字幕| 免费黄色福利视频| 天天av天天操| 国产精品一色哟哟| 免费日韩中文字幕| 天天干天天操天天干天天操| 久久久久久久香蕉| 毛葺葺老太做受视频| 亚洲热在线视频| 欧美啪啪免费视频| 国产乱码一区二区三区四区| 国产精品久久久久7777| 大香煮伊手机一区| 成年丰满熟妇午夜免费视频 | 亚洲欧美另类动漫| 干日本少妇视频| 成人一级片网站| 国产黑丝在线视频| 播放灌醉水嫩大学生国内精品| 欧美日韩一区二区三区69堂| 国产 欧美 日本| 麻豆一区二区三区视频| 国产又粗又猛又爽又黄的网站| 欧美私人情侣网站| 免费一级淫片aaa片毛片a级| 国产三级生活片| 免费av网址在线| 男人天堂新网址| 91丝袜超薄交口足| 国产欧美高清在线| 免费看毛片的网址| 路边理发店露脸熟妇泻火| 污污视频网站免费观看| 成人综合视频在线| 国产精品igao激情视频| 亚洲综合20p| 日韩手机在线观看视频| 熟女少妇在线视频播放| 国产成人免费高清视频| 91av视频免费观看| 国产精品v日韩精品v在线观看| jizzjizzxxxx| av7777777| 国产99久久九九精品无码| 精品视频在线观看一区| www.成年人视频| 成人免费播放器| 99精品在线免费视频| 日韩精品 欧美| 男人靠女人免费视频网站| 精品少妇一区二区三区在线| 91精品国产91久久久久麻豆 主演| 日韩久久久久久久久久久久| 欧美aaa在线观看| av 日韩 人妻 黑人 综合 无码| 中文字幕55页| 青青青在线观看视频| 日韩美女爱爱视频| 婷婷无套内射影院| 黄色a级片免费| 日本在线观看免费视频| 久久精品一卡二卡| 成人短视频在线观看免费| 国产精品久久久久9999爆乳| 国产av麻豆mag剧集| 黄色av免费在线播放| 欧美三级理论片| 欧美性受xxxx黑人猛交88| bt天堂新版中文在线地址| 欧美丰满熟妇bbbbbb百度| av五月天在线| av磁力番号网| 116极品美女午夜一级| 热久久精品免费视频| 一级黄色高清视频| a级黄色一级片| 亚洲 国产 图片| 僵尸世界大战2 在线播放| 一区二区xxx| 国产精品12p| 免费在线观看毛片网站| 潘金莲一级淫片aaaaa免费看| 欧美日韩在线一| 天天av天天操| 韩国一区二区av| 日韩最新中文字幕| 婷婷激情四射五月天| 免费视频爱爱太爽了| 亚洲天堂2018av| 男女视频网站在线观看| 欧洲美女亚洲激情| 青青在线免费观看视频| 久久手机在线视频| 在线视频观看91| 免费日韩视频在线观看| 波多野结衣与黑人| 天天看片天天操| 538在线视频观看| 黑人糟蹋人妻hd中文字幕| 成人黄色片免费| 国产精品999.| 中文字幕22页| 91香蕉视频污版| 免费黄色福利视频| www.日本在线播放| 九九久久九九久久| 天堂av免费看| 中文字幕在线视频一区二区| 久久国产精品国产精品| 国产成人综合一区| 免费在线激情视频| 99精品视频播放| 天天操天天摸天天爽| 国产三级三级三级看三级| 激情视频综合网| 天堂中文视频在线|