為什么要使用JSON格式記錄日志

這篇文章主要介紹“為什么要使用JSON格式記錄日志”,在日常操作中,相信很多人在為什么要使用JSON格式記錄日志問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”為什么要使用JSON格式記錄日志”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序設(shè)計(jì)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了蟠龍免費(fèi)建站歡迎大家使用!

日志和監(jiān)控就像 TonyStark 和他的 IronMan 西裝一樣,兩者需要一起使用才能發(fā)揮最大的威力,因?yàn)樗鼈兛梢院芎没パa(bǔ)。

為什么要使用JSON格式記錄日志

日志一直是應(yīng)用程序和基礎(chǔ)框架性能和故障診斷的重要手段,但是現(xiàn)在我們已經(jīng)意識到日志不僅可以用于故障診斷,還可以用于大數(shù)據(jù)分析以及業(yè)務(wù)的一些可視化和性能分析等等。

所以,記錄應(yīng)用程序日志是非常非常重要的。

為什么使用 JSON 格式

為了了解 JSON 日志記錄的優(yōu)越性,我們先來了解下 Anuj(系統(tǒng)工程師)和 Kartik(業(yè)務(wù)分析師)之間的一次對話。

為什么要使用JSON格式記錄日志

但是幾天后 Kartik 發(fā)現(xiàn) Web 接口掛掉了,Anuj 摸了摸頭,看了看日志,發(fā)現(xiàn)是開發(fā)人員在日志中添加了一個(gè)額外的字段,這破壞了他自定義的日志解析器。

我相信很多童鞋都可能遇到過類似的情況吧?

在這種情況下,如果開發(fā)人員將應(yīng)用程序設(shè)計(jì)為 JSON 格式的日志,那么 Anuj 定義的解析器就非常簡單了,然后基于 JSON 的 key 搜索字段就可以了,而不需要關(guān)心是否在日志中修改了新的字段。

使用 JSON 格式的日志最大的好處就是它本身就是結(jié)構(gòu)化的,這樣我們?nèi)シ治鰬?yīng)用日志就非常方便了,不僅可以方便讀取日志,還可以通過每個(gè)字段進(jìn)行日志查詢,而且?guī)缀跛芯幊陶Z言都可以很輕松的解析它。

JSON 日志魔法

最近我們創(chuàng)建了一個(gè) Golang 示例應(yīng)用程序,來獲取代碼構(gòu)建、測試和部署階段的一些相關(guān)信息,我們就采用了使用 JSON 格式的日志進(jìn)行記錄。

采集的日志樣本如下所示:

為什么要使用JSON格式記錄日志

在使用 ELK 進(jìn)行日志收集的時(shí)候,我們只需要在 Logstash 中添加如下所示的日志解析即可:

  
    
  
  
  filter { json { source => "message" }}

我們不需要任何額外的解析步驟,即使在日志中添加了新的字段。采集到的日志如下圖所示:

為什么要使用JSON格式記錄日志

我們可以看到在 Kibana 中已經(jīng)將 JSON 日志的 key 自動解析為了 ES 的屬性,比如 employeename、employeecity 等字段,我們完全不需要在 Logstash 或者其他工具中去添加一些非常復(fù)雜的解析,現(xiàn)在我們使用這些數(shù)據(jù)去創(chuàng)建一些 Dashboard 進(jìn)行數(shù)據(jù)分析就非常容易了。

結(jié)論

從文本日志遷移到 JSON 日志格式并不會花費(fèi)太長時(shí)間,大部分編程語言都有對應(yīng)的 JSON 日志庫,我非常確信 JSON 日志格式會為你當(dāng)前的日志收集系統(tǒng)提供更大的靈活性。

下面是一些支持 JSON 日志格式的流行的庫:

  • Golang - https://github.com/sirupsen/logrus

  • Python - https://github.com/thangbn/json-logging-python

  • Java - https://howtodoinjava.com/log4j2/log4j-2-json-configuration-example/

  • PHP - https://github.com/nekonomokochan/php-json-logger

到此,關(guān)于“為什么要使用JSON格式記錄日志”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

網(wǎng)頁名稱:為什么要使用JSON格式記錄日志
文章URL:http://bm7419.com/article40/jjchho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、動態(tài)網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站收錄、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化