精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

日志到底應該怎么打?。?/h1> 原創

開發 前端
寫代碼的人就沒有不寫日志的,但我們到底該怎么打印日志,打印日志能不能有點章法?

[[385165]]

【51CTO.com原創稿件】前言

寫代碼的人就沒有不寫日志的,但我們到底該怎么打印日志,打印日志能不能有點章法?

針對這個問題,我查閱了《阿里巴巴Java開發手冊》,里面有 8 條日志規約。比如不同作用的日志存放到不同的日志文件里,以 appName_logType_logName.log 方式進行命名。是挺不錯,但屬于是日志分類的問題,依舊解決不了程序員如何有章法的在代碼中書寫日志的問題。

探尋

先來看一個比較常見的日志打印示例:

  1. log.info("開始執行業務邏輯 ----------------->{}",param); 
  2. log.info("業務邏輯執行中 ----------------->{}",param); 
  3. log.info("結束執行業務邏輯 ----------------->{}",param); 
  4. log.error("業務執行異常 ----------------->{}",param, e); 

這種日志打印有什么問題?

第一、沒有綁定事件

在執行什么業務邏輯呢?沒有一個明確的事件,或者說是名字、歸類,我更愿稱之為事件。我們搜索日志時,是要有一個主語的,如果在日志打印中加入事件,我們搜索日志時,只需要輸入關鍵字即可獲取該事件的所有日志。改進后的⽇志打?。?/p>

  1. log.info("{}|開始執行業務邏輯 ----------------->{}",EVENT_NAME, param); 
  2. log.info("{}|業務邏輯執行中 ----------------->{}",EVENT_NAME, param); 
  3. log.info("{}|結束執行業務邏輯 ----------------->{}",EVENT_NAME, param); 
  4. log.error("{}|業務執行異常 ----------------->{}",EVENT_NAME, param, e); 

第二、沒有綁定主鍵

一個事件下的日志無時無刻不在產生,而發生問題時,往往只會給你一個 case 進行診斷,所以,我們除了記錄事件,還需要記錄主鍵,通過觀察這個主鍵在執行過程中都產生了哪些日志來定位問題。改進后的日志打?。?/p>

  1. log.info("{}|ID={}|開始執行業務邏輯 ----------------->{}",EVENT_NAME, ID, param); 
  2. log.info("{}|ID={}|業務邏輯執行中 ----------------->{}",EVENT_NAME, ID, param); 
  3. log.info("{}|ID={}|結束執行業務邏輯 ----------------->{}",EVENT_NAME, ID, param); 
  4. log.error("{}|ID={}|業務執行異常 ----------------->{}",EVENT_NAME, ID, param, e); 

第三、沒有綁定請求

有了事件,有了主鍵,但是在查詢日志的過程中,發現該主鍵產生了許多重復日志,日志的上下文不連貫,我們想看某一次請求產生的連續日志就非常不方便,這時候就需要考慮并發的情況。改進后的日志打?。?/p>

  1. // 可以使用 UUID 生成ReqId 
  2. // final String ReqId = UUID.randomUUID().toString(); 
  3. log.info("{}|ReqId={}|ID={}|開始執行業務邏輯 ----------------->{}",EVENT_NAME, ReqId, ID, param); 
  4. log.info("{}|ReqId={}|ID={}|業務邏輯執行中 ----------------->{}",EVENT_NAME, ReqId, ID, param); 
  5. log.info("{}|ReqId={}|ID={}|結束執行業務邏輯 ----------------->{}",EVENT_NAME, ReqId, ID, param); 
  6. log.error("{}|ReqId={}|ID={}|業務執行異常 ----------------->{}",EVENT_NAME, ReqId, ID, param, e); 

第四、沒有綁定分詞符

不要在日志打印時使用 --- 這種分隔符,沒意義、不標準,非常不好做分詞。一定要將不變的文字說明和變化的參數用分詞符分開打印,因為不變的文字說明也是可以成為關鍵詞進行搜索的。改進后的日志打?。?/p>

  1. log.info("{}|ReqId={}|ID={}|開始執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 
  2. log.info("{}|ReqId={}|ID={}|業務邏輯執行中|參數={}",EVENT_NAME, ReqId, ID, param); 
  3. log.info("{}|ReqId={}|ID={}|結束執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 
  4. log.error("{}|ReqId={}|ID={}|業務執行異常|參數={}",EVENT_NAME, ReqId, ID, param, e); 

第五、錯誤日志需要輸出異常信息

對于異常日志的打印一定要帶上堆棧信息,異常堆棧不能使用 e.printStackTrace() 輸出到控制臺,這樣異常堆棧是寫入不了日志文件的,需要將異常對象寫進最后的參數里,這點相信大家都懂。

除此之外,還需要將異常信息的 toString() 內容打印進同一行日志里。因為異常堆棧都是另起一行,對于一些單行日志記錄的系統,比如阿里云sls,根本看不到異常信息,還得爬進服務器找日志堆棧。所以,還是很有必要將 e.toString() 寫進參數里的,有些異常只看 e.toString() 的內容就可以定位了。為什么我這里要求使用 e.toString() 而不是 e.getMessage() ?因為如果是NullPointerException異常, e.getMessage() 返回空。改進后的代碼:

  1. log.error("{}|ReqId={}|ID={}|業務執行異常|參數={}|e={}",EVENT_NAME, ReqId, ID, param, e.toString(), e); 

第六、若有循環,需要綁定循環主鍵

將上面例子加個業務上的循環,再來看下代碼:

  1. log.info("{}|ReqId={}|ID={}|開始執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 
  2. for (Key key : KeyList) { 
  3. log.info("{}|ReqId={}|ID={}|業務邏輯執行中|參數={}",EVENT_NAME, ReqId, ID, param); 
  4. log.info("{}|ReqId={}|ID={}|結束執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 

這樣產生的日志,非常不方便定位到具體的某次循環。如果循環體內出了異常,也不清楚具體是哪個Key 引發的。所以,遇到業務邏輯位于循環內的代碼,應該打印出每次處理的 Key。改進后的代碼:

  1. log.info("{}|ReqId={}|ID={}|開始執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 
  2. for (Key key : KeyList) { 
  3. log.info("{}|ReqId={}|ID={}|Key={}|業務邏輯執行中|參數={}",EVENT_NAME, ReqId, ID, key, param); 
  4. log.info("{}|ReqId={}|ID={}|結束執行業務邏輯|參數={}",EVENT_NAME, ReqId, ID, param); 

公式

經過上面的分析之后,我們可以總結出日志打印的公式:

  1. EVENT_NAME={}|ReqId={}|Key={}|childKey={}|doing something|result={} 

如果沒有過程的話,ReqId 是可以省略的,Key 的數量也不一定只是一個,你也可以看情況給日志加一列 [start|end] ,表示業務過程的開始和結束。

JSON日志

之前有段時間寫過 JSON 格式的日志,就是每一個行日志都是一個 JSON 串,上面講到的日志可以稱為單行日志。

舉個例子:

  1. Map<String, Object> logMap = new HashMap<>(); 
  2. try{ 
  3. logMap.put("EVENT_NAME""monitor"); 
  4. // .... 
  5. }finally { 
  6. LogUtil.save(JSON.toJSONString(logMap)); 

輸出日志(為了方便查看,我已格式化):

  1. "EVENT_NAME""monitor"
  2. "ReqId""654321"
  3. "ID""123456"
  4. "success"true
  5. "param": { 
  6. "name""zs"
  7. "age": 14 
  8.  } 

JSON 日志天然綁定了請求過程,它最大的優勢是輸出序列化好的 JSON 串,非常方便離線對其各種操作。但對比于單行日志,代碼嵌入性太高,需要通過 try..finally 代碼塊進行捕捉。

主⻚:https://github.com/onblog

PS:以前我喜歡用 JSON 日志,現在我更喜歡用單行日志

【51CTO原創稿件,合作站點轉載請注明原文作者和出處為51CTO.com】

責任編輯:華軒 來源: 51CTO
相關推薦

2021-01-15 19:10:32

日志打印原則

2016-06-01 11:27:24

2020-09-15 12:59:48

KotlinFlutter移動

2021-05-10 06:58:41

ChromeFlash版本號

2021-01-21 05:51:52

Chrome FlashWindows

2015-09-08 09:20:49

案例研究混合云云部署

2020-06-23 14:28:24

MySQL商品數據

2020-05-11 23:18:09

內存條CPU插槽

2023-11-24 08:17:38

金額類型存儲

2011-08-29 09:45:09

2014-01-07 13:54:40

Hadoop日志

2019-03-18 10:32:33

容災雙活同城

2022-12-29 07:24:55

打印日志Python

2015-11-05 09:26:34

Fedora發行版Linux

2023-03-24 12:52:22

2024-06-27 08:04:39

2020-04-30 14:38:51

數據庫連接池線程

2021-08-30 11:43:46

程序員技能開發者

2020-06-17 10:35:16

機器學習AI人工智能

2010-01-07 10:09:38

千兆網絡交換機
點贊
收藏

51CTO技術棧公眾號

18性欧美xxxⅹ性满足| 亚洲国产视频直播| 国产精品视频久久久| xxxxx99| 日韩国产大片| 在线免费观看日本欧美爱情大片| 日韩欧美资源站| 色欲av无码一区二区人妻| av福利在线播放| 国产精品亚洲人在线观看| 欧美一区二区三区免费视| 色婷婷粉嫩av| 亚洲区小说区| 日韩精品一区二区三区三区免费| 六月激情综合网| 在线黄色网页| 中文字幕av一区二区三区免费看 | 日韩久久免费视频| 久久6免费视频| 日韩a**中文字幕| 亚洲成人激情综合网| 亚洲巨乳在线观看| 色视频精品视频在线观看| 韩国一区二区在线观看| 日韩美女写真福利在线观看| 在线看成人av| 欧美日韩hd| 日韩在线视频播放| 久久久久久久久久久国产精品| 视频欧美一区| 欧美精品九九99久久| 日本一本二本在线观看| 999av小视频在线| 亚洲丝袜另类动漫二区| 婷婷亚洲婷婷综合色香五月| 三级视频在线播放| 成人av在线播放网址| 亚洲最大的av网站| 91久久国语露脸精品国产高跟| 久久精品二区三区| 热久久99这里有精品| 日韩精品一区二区三| 国产一区久久| 久久久久国产精品一区| 亚洲熟女少妇一区二区| 日韩88av| 日韩中文字幕在线看| 亚洲图片第一页| 久久精品高清| 久久在精品线影院精品国产| 熟女少妇a性色生活片毛片| 俺要去色综合狠狠| 国产香蕉精品视频一区二区三区| 在线免费观看日韩av| 在线观看欧美理论a影院| 国产婷婷成人久久av免费高清| 岛国精品资源网站| 欧洲亚洲一区二区三区| 日韩成人av在线| 国产69精品久久久久久久| 手机在线免费观看av| 亚洲一区二区av在线| 少妇大叫太大太粗太爽了a片小说| 日本一本在线免费福利| 亚洲最大成人网4388xx| 国产日本在线播放| 中文字幕资源网在线观看免费| 精品欧美激情精品一区| aⅴ在线免费观看| 国产成人77亚洲精品www| 欧美日韩高清一区| 一起草最新网址| 精品欠久久久中文字幕加勒比| 亚洲成人在线网| 泷泽萝拉在线播放| 日本一区二区在线看| 久久亚洲春色中文字幕| 国产亚洲精品久久久久久无几年桃| 影音先锋一区| 国产成人精品优优av| 亚洲怡红院av| 国产69精品久久久久毛片| 国产精品一区二区三区免费| 青青草免费在线视频| 国产精品成人免费| 日韩av中文字幕第一页| 中文字幕成在线观看| 欧美日韩亚洲高清一区二区| 超级砰砰砰97免费观看最新一期| 果冻天美麻豆一区二区国产| 国产一区二区三区视频| 亚洲天堂黄色片| aa亚洲婷婷| 国产主播在线一区| 五月婷婷六月色| 最新国产成人在线观看| 国产精品免费入口| 精品国产伦一区二区三区观看说明 | 国产日本欧美一区二区| www.国产亚洲| 外国电影一区二区| 337p日本欧洲亚洲大胆精品| 色屁屁草草影院ccyy.com| 欧美特黄一级| 国产精品96久久久久久| 亚洲av无码国产综合专区| 国产夜色精品一区二区av| 成人午夜免费在线视频| 秋霞国产精品| 亚洲激情中文字幕| 久久久精品视频免费观看| 久久国产精品毛片| 国产成人一区二区三区免费看| 亚洲搞黄视频| 欧美午夜电影在线| 国产精九九网站漫画| 日韩精品电影| 国产91精品在线播放| 男人天堂av网| 一区二区三区欧美激情| 国产高清视频网站| 欧美猛男男男激情videos| 欧美激情网站在线观看| 国产日韩欧美一区二区东京热| 国产色爱av资源综合区| aa在线免费观看| 大型av综合网站| 欧美麻豆久久久久久中文| 亚洲一卡二卡在线观看| 国产三级精品在线| 欧美日韩在线不卡视频| 欧美日韩一区二区三区不卡视频| 九九精品在线视频| 国产免费一区二区三区最新不卡| 国产精品污www在线观看| 国产免费视频传媒| 精品72久久久久中文字幕| 国产91精品高潮白浆喷水| 内射后入在线观看一区| 亚洲永久精品大片| 深夜视频在线观看| 欧美特黄一级| 国产精品久久久久免费| 国产又色又爽又黄刺激在线视频| 911精品产国品一二三产区 | 亚洲影视在线播放| 亚洲熟妇一区二区| 亚洲网站视频| 国产偷国产偷亚洲高清97cao| 久久亚洲导航| 亚洲国产精品一区二区久| 日韩精品一区二区av| 99久久精品免费看国产免费软件| 妞干网在线观看视频| 欧美福利在线播放网址导航| 91成人在线播放| 日本黄在线观看| 日韩欧美国产视频| 日本欧美一区二区三区不卡视频| 日韩二区三区四区| 亚洲一区二区在线免费观看| 九九热这里有精品| 北条麻妃99精品青青久久| 国产又粗又猛又黄| 亚洲免费视频成人| www.com日本| 中文一区在线| 欧美亚洲精品日韩| 色婷婷成人网| 久久久久久久久久久91| 日韩一二三四| 欧美精品久久久久久久多人混战| 亚洲国产成人精品综合99| 从欧美一区二区三区| 成年人看的毛片| 九九精品久久| 成人乱色短篇合集| a毛片不卡免费看片| 亚洲精品一区二三区不卡| 中文字幕第三页| 一区二区视频在线看| 日韩精品人妻中文字幕有码| 天堂一区二区在线免费观看| 一区二区三区国产福利| 97青娱国产盛宴精品视频| 欧美性资源免费| 韩国av网站在线| 亚洲黄色免费三级| 在线观看中文字幕2021| 亚洲综合色网站| 国产jjizz一区二区三区视频| 国内精品第一页| 欧美视频在线播放一区| 色喇叭免费久久综合网| 国产乱码精品一区二区三区日韩精品| 日韩制服诱惑| 欧美激情亚洲自拍| 美女羞羞视频在线观看| 亚洲精品狠狠操| 国产精品一区二区人人爽| 欧美性生交xxxxxdddd| 欧美 日韩 国产 一区二区三区| 97se亚洲国产综合在线| 久久久久久国产精品日本| 久久激情婷婷| 成人黄色av片| 午夜国产精品视频| 婷婷久久伊人| 亚洲aa在线| 高清不卡一区二区三区| 天天综合91| 国产91久久婷婷一区二区| 天堂av免费看| 日本高清视频免费观看| 欧美图片一区二区三区| 日韩xxx高潮hd| 亚洲女女做受ⅹxx高潮| 中文幕无线码中文字蜜桃| 国产成人午夜精品影院观看视频| 亚洲成人av免费看| 国产精品日韩| 精品无码国产一区二区三区av| 99久久99热这里只有精品| 欧美一级日本a级v片| 国产伦精品一区二区三区免费优势 | 特黄一区二区三区| 久久奇米777| 亚洲av人人澡人人爽人人夜夜| 久久99精品久久久久久| 一级黄色香蕉视频| 久久成人免费| 日本精品免费在线观看| 精品91在线| 欧美黑人在线观看| 午夜国产欧美理论在线播放| 一区二区日本伦理| 欧美丰满老妇| 在线国产99| 亚洲h色精品| 亚洲第一精品区| 日韩成人精品一区二区| 神马欧美一区二区| 成人免费a**址| 亚洲精品国产精品国自产观看| 成人6969www免费视频| 色狠狠久久av五月综合|| 精品久久成人| 日本一区二区免费看| 国产欧美日韩精品高清二区综合区| 六月婷婷久久| 国内精品视频在线观看| 日韩精品不卡| 日本电影一区二区| 一区二区免费在线观看| 亚洲一区二区日韩| 人妻互换免费中文字幕| 韩国在线视频一区| 国产精品久久中文字幕| 一本久道久久综合婷婷鲸鱼| 欧美韩国日本在线| 免费看日韩精品| 99九九精品视频| 国产成人精品www牛牛影视| 大桥未久恸哭の女教师| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 电影一区二区三| 国产精品电影一区| 午夜精品久久久久久毛片| 亚洲影院高清在线| 丁香一区二区| 欧美日韩精品久久久免费观看| 日韩成人激情| 久久久久久久9| 久久激情视频| 国产大片一区二区三区| 成人免费毛片高清视频| 国产ts在线播放| 亚洲欧美一区二区不卡| 日韩av一二三区| 91国模大尺度私拍在线视频| 国产精品久久久久久久久毛片 | 精品欧美一区二区久久久伦| 九九久久婷婷| 蜜桃网站在线观看| 久久国产精品久久w女人spa| www.久久91| 不卡视频在线观看| 久久精品国产亚洲AV成人婷婷| 亚洲精品videosex极品| 亚洲精品中文字幕乱码三区91| 欧美人妇做爰xxxⅹ性高电影| 人妻视频一区二区三区| 中文字幕一区电影| av在线不卡免费| 国产精品一区二区三区毛片淫片| 天堂av一区| 天堂社区 天堂综合网 天堂资源最新版 | 国产一区二区美女视频| 色在线视频网| 国产玖玖精品视频| 欧美中文一区| 奇米777四色影视在线看| 爽好久久久欧美精品| 国产精品偷伦视频免费观看了| 久久精品亚洲国产奇米99| 一区二区三区免费高清视频 | 国产精品拍拍拍| 成人黄色在线网站| www.97视频| 在线免费观看日韩欧美| 丁香花免费高清完整在线播放| 在线观看欧美日韩| 日本午夜大片a在线观看| 444亚洲人体| 欧美国产一级| 精品久久久久久久无码| 99久久精品费精品国产一区二区| 成人在线观看高清| 欧美三级中文字| 青青青免费视频在线2| 欧美第一页在线| 国产精品一级在线观看| 日韩免费一区二区三区| 一本色道久久综合亚洲精品高清 | 亚洲乱码中文字幕| 中文字幕一区二区三区四区视频| 日韩激情视频在线| 免费电影网站在线视频观看福利| 成人免费福利在线| 日韩中文首页| 午夜dv内射一区二区| 91麻豆精品一区二区三区| 国产午夜福利片| 精品久久久久久久久久久久包黑料| 亚洲麻豆精品| 成人h猎奇视频网站| 欧美亚洲激情| 另类小说第一页| 国产精品丝袜一区| 97人妻精品视频一区| 国产一区二区三区直播精品电影| 成人香蕉视频| 日韩少妇中文字幕| 日本系列欧美系列| 日韩欧美视频免费观看| 欧美日韩久久一区| 免费网站看v片在线a| 成人亚洲欧美一区二区三区| 91精品天堂福利在线观看| 久久久久久久久久一区二区| 蜜桃视频www网站在线观看| 中文字幕不卡在线| 国产高清精品一区| 人妻中文字幕一区二区三区| 好看的日韩av电影| 久久综合国产精品台湾中文娱乐网| 法国伦理少妇愉情| 日韩有码av| 日韩精品亚洲元码| 性色av蜜臀av浪潮av老女人 | 蜜桃av噜噜一区二区三区麻豆| 蜜臀av一级做a爰片久久| 欧美成人精品影院| 手机看片福利视频| 美日韩精品视频| 素人fc2av清纯18岁| 在线观看亚洲精品| 99se视频在线观看| 成人激情视频小说免费下载| 中文字幕免费一区二区三区| 男生和女生一起差差差视频| 亚洲国产视频a| 免费在线观看一级毛片| 国产精品美女久久久久久免费 | 国产一区二区福利| 久久午夜鲁丝片午夜精品| 日韩精品极品在线观看| av高清一区| 五月天在线免费视频| 成年人国产精品| 国产精品欧美综合| 欧美成人午夜剧场免费观看| 久久久久高潮毛片免费全部播放| 日日摸天天爽天天爽视频| 成人欧美一区二区三区小说| 亚洲精品一区二区口爆| 国产97免费视| 国产精品videosex极品| 四虎永久免费影院| 欧美一区二区三区视频| 国产高清自产拍av在线| 无码免费一区二区三区免费播放 | 中文在线а√天堂| 久久免费视频2| 91免费在线看| 99这里有精品视频| 国产精品 欧美在线| 欧美女人交a| 大吊一区二区三区| 日韩电影中文字幕在线|