中小型研發團隊架構實踐七:集中式日誌ELK

来源:https://www.cnblogs.com/supersnowyao/archive/2018/01/29/8375926.html
-Advertisement-
Play Games

一、集中式日誌 日誌可分為系統日誌、應用日誌以及業務日誌,系統日誌給運維人員使用,應用日誌給研發人員使用,業務日誌給業務操作人員使用。我們這裡主要講解應用日誌,通過應用日誌來瞭解應用的信息和狀態,以及分析應用錯誤發生的原因等。 隨著系統的日益複雜,大數據時代的來臨,需要幾十甚至上百台的伺服器是常有的 ...


一、集中式日誌

     日誌可分為系統日誌、應用日誌以及業務日誌,系統日誌給運維人員使用,應用日誌給研發人員使用,業務日誌給業務操作人員使用。我們這裡主要講解應用日誌,通過應用日誌來瞭解應用的信息和狀態,以及分析應用錯誤發生的原因等。

     隨著系統的日益複雜,大數據時代的來臨,需要幾十甚至上百台的伺服器是常有的事,因此迫切需要有一套針對日誌、且能夠集中式管理的產品。ELK 就實現了集中式日誌管理平臺,該平臺統一涵蓋了分散式日誌收集、檢索、統計、分析以及對日誌信息的 Web 管理等集中化管控。

1.1、ELK 簡介

     ELK 是 Elasticsearch、Logstash、Kibana 的簡稱,這三套開源工具組合起來能搭建一套強大的集中式日誌管理平臺。

     Elasticsearch 是個開源的分散式搜索引擎,提供搜索、分析、存儲數據三大功能。它的特點有:分散式、自動發現、索引自動分片、索引副本機制、RESTful 風格介面、多數據源以及自動搜索負載等。

     Logstash 是一個開源的用來收集、解析、過濾日誌的工具。支持幾乎任何類型的日誌,包括系統日誌、業務日誌和安全日誌。它可以從許多來源接收日誌,這些來源主要包括 Syslog、消息傳遞(例如 RabbitMQ)和 Filebeat;能夠以多種方式輸出數據,這些方式主要包括電子郵件、WebSockets 和 Elasticsearch。

     Kibana 是一個基於 Web 的友好圖形界面,用於搜索、分析和可視化存儲在 Elasticsearch 中的數據。它利用 Elasticsearch 的 RESTful 介面來檢索數據,不僅允許用戶定製儀錶板視圖,還允許他們以特殊的方式查詢、彙總和過濾數據。

1.2、ELK 的架構

     下圖是集中式日誌管理 ELK 的架構圖。出於性能的考慮,選擇採用了 Beats+EK 的形式來組合搭建集中式日誌管理系統。

    

                                                                           ELK 架構

 

二、配置方法

2.1、Elasticsearch

     Elasticsearch 部署完成後,需要更改 elasticsearch.yml 配置文件中的主要屬性:cluster.name、node.name、network.host、discovery.zen.ping.unicast.hosts。其中,當部署 Elasticsearch 時是以集群模式部署的,那麼 discovery.zen.ping.unicast.hosts 這個屬性才會需要被配置。

2.2、Logstash

     通過配置 filebeat-pipeline.conf 文件中的 Input、Filter(可選)和 Output 來完成對數據的採集、過濾和輸出,如下圖所示:

     

                                        Logstash 配置

     然後以 filebeat-pipline.conf 文件啟用 Logstash 服務,如下圖所示:

      

                                                       啟用 Logstash 服務

     備註:由於採用的是 Beats+EK 這個方案來實現集中式日誌管理,所以不需要配 Logstash。

2.3、Kibana

     通過更改 kibana.yml 配置文件內容,用來連接正確的 Elasticsearch 服務地址,通常只需要配置 elasticsearch.url 屬性即可,請見下圖的第一個圖。配置完成後,執行【bin/kibana &】命令啟用 Kibana 服務,請見下圖的第二個圖。最後就可以在瀏覽器中打開 Kibana 管理頁面(訪問地址:http://139.198.13.12:4800/)來查看日誌。

 

                                                       Kibana 的配置說明

 

                                                       啟用 Kibana 服務

2.4、Filebeat

     filebeat.yml 配置文件內容主要包含 Filebeat、Output、Shipper(可選)、Logging(可選)四大部分,其中 Filebeat 主要定義監控的日誌文件信息,Output 主要配置日誌數據的輸出目標。

     filebeat.yml 文件中,主要屬性值的命名規範如下:

  1. fields.AppID 的命名規範是{AppID}。
  2. fields.AppName 的命名規範是{產品線英文名稱}.{項目英文名稱}(如果項目英文名稱由 2 個或 2 個以上英文單片語成,則單詞之間請用. 分隔)。
  3. 針對 index 屬性需要註意的是:索引 (index) 所定義的值是{產品線英文名稱},但英文字母必須全部小寫,且不能以下劃線開頭,也不能包含逗號。

     filebeat.yml 的配置示例如下圖所示:

      

                                                       filebeat.yml 的配置示例

     日誌文件存放在哪台伺服器中,filebeat 服務就部署在哪台伺服器中。在 windows 操作系統上啟用 filebeat 服務的步驟:

     1、在 windows 下開啟搜索,輸入 powershell,打開 powershell 所在文件位置,右鍵 powershell.exe 以管理員身份運行,進入 PowerShell 視窗。

     或者以管理員身份啟動 cmd.exe,輸入命令 powershell,進入 PowerShell 視窗 。

     註意:

     請務必確保以管理員身份打開 PowerShell 視窗,否則的話在以下第 2 步中運行.ps1 腳本時,就會報沒有許可權創建 filebeat 服務的錯誤:

     

     2、導向到 filebeat 執行程式所在目錄,例如:cd 'E:\ELK\filebeat-1.3.0-windows',然後執行命令:powershell.exe -ExecutionPolicy UnRestricted -File .\install-service-filebeat.ps1。

     3、之後可以在 PowerShell 視窗中通過以下幾個命令來查看、啟用以及停止 filebeat 服務:

  • 查看 filebeat 服務狀態:Get-Service filebeat
  • 啟動 filebeat 服務:Start-Service filebeat
  • 停止 filebeat 服務:Stop-Service filebeat

 

三、使用方法

3.1、Log4Net 本地日誌

     1、日誌存放路徑規範:{盤符}:\Log4Net{AppID}\,其中 AppID 即為我們所做項目的六位編碼。例如:D:\Log4Net\110107\。

     2、log4net.config 配置內容:

 1 <?xml version="1.0" encoding="utf-8" ?>
 2 <configuration>
 3   <configSections>
 4     <section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
 5   </configSections>
 6   <appSettings>
 7   </appSettings>
 8   <log4net>
 9     <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
10       <!--AppID 150202,用於區分哪個應用的日誌 -->     
11       <file value="D:\Log4Net\150202\" />
12       <rollingStyle value="Composite" />
13       <datePattern value="yyyy-MM-dd&quot;.log&quot;" />
14       <staticLogFileName value="false" />
15       <param name="Encoding" value="utf-8" />  
16       <maximumFileSize value="100MB" />      
17       <countDirection value="0" />         
18       <maxSizeRollBackups value="100" />
19       <appendToFile value="true" />      
20       <layout type="log4net.Layout.PatternLayout">
21         <conversionPattern value="記錄時間:%date 線程:[%thread] 日誌級別:%-5level 記錄類:%logger 日誌消息:%message%newline" />
22       </layout>
23     </appender>
24     <logger name="FileLogger" additivity="false">    
25       <level value="DEBUG" />
26       <appender-ref ref="FileAppender" />
27     </logger>     
28   </log4net>
29 </configuration>

     註意了:

  • maximumFileSize 設置為 100MB;請給 countDirection 設置為大於 -1 的整數;maxSizeRollBackups 設置為 100。
  • 日誌文件內容規範:日誌文件中的每條日誌內容要求是“記錄時間 線程 日誌級別 出錯類 日誌消息”。

3.2、日誌查詢

     基於 Kibana 查詢日誌(訪問地址:http://139.198.13.12:4800/),主要通過以下幾個步驟實現:

  1. 選擇業務索引庫。
  2. 選擇日期範圍。
  3. 輸入待查找的內容實現精確查詢,也可以通過輸入 * 實現模糊查詢。
  4. 點擊每條日誌的展開圖標,可以查看該條日誌的詳細信息。
  5. 在 Kibana 界面的左側區域,自上而下依次是索引庫選擇框、選中欄位集合列表(Selected Fields)、可用欄位集合列表(Available Fields)。通過添加可用欄位到選中欄位集合列表中來改變 Kibana 右側的日誌表格呈現。

     請參考如下圖所示:

     

                                                                 Kibana 查詢日誌界面

 

四、Demo 下載及更多資料

 

轉載地址:http://www.infoq.com/cn/articles/architecture-practice-03-elk?utm_source=infoq&utm_campaign=user_page&utm_medium=link


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這裡講到了一條語句運行多個JQuery方法(同一個元素)和動畫100%完成後執行的callback方法。 ...
  • 創建百度聯盟廣告位的時候,選擇按父容器寬度展示,但是在加入之後,查看代碼發現廣告的寬度為頁面的寬度,並不是希望的父級的寬度, 如圖在這裡查看: 解析:百度聯盟廣告自動生成的div按父級的div寬度來自適應,如果父級是一個包含padding的div,則父級的寬度為padding+本身的寬,然而,我們希 ...
  • 在百度聯盟代碼位管理中創建好對應的代碼位之後,點擊獲取代碼,會看到這樣一段js 直接複製粘貼到自己網頁中便可顯示對應廣告。 在vue中由於都是vue組件,不支持直接在組件中加入這樣一段一段的js代碼,我們採用如下方法: 1、首先在index.html中引入生成的代碼中的js, 2、在vue組件中在想 ...
  • flexible.js是淘寶推出的一款移動端手機自適應的庫,源碼內容很簡潔,當網頁使用了該庫之後,頁面會在head中加入對應的頁面響應式的meta標簽。 當使用flexible.js的時候,引入百度聯盟的廣告代碼,會發現廣告的文字會異常小,因為本身自己項目文字字型大小是根據data-dpr來響應式判斷顯 ...
  • 效果如下: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Title</title> 6 </head> 7 <style> 8 td,th{ 9 border: 1px solid g ...
  • 最近在做一個後臺管理系統,前端是用時下火熱的vue.js,後臺是基於springboot的。因為後臺系統沒有登錄功能,但是公司要求統一登錄,登錄認證統一使用.net項目組的認證系統。那就意味著做單點登錄咯,至於不知道什麼是單點登錄的同學,建議去找一下萬能的度娘。 剛接到這個需求的時候,老夫心裡便不屑 ...
  • 橋模式對於理解 開閉原則 與 組合聚合復用原則 很有幫助,同時也可以加深對於繼承的認識.這也是一個聽起來奇妙,用起來好像似曾相識,或者說早就不經意間就使用過的模式. 用意 將抽象與實現解耦,使二者可以獨立變化. 毫無疑問,用意概括的非常簡練,初次接觸這個模式的人很難參悟到其中的奧妙.軟體的模式要在一 ...
  • 1.餓漢式、不支持併發: 此模式只能運行在單線程下,且類在載入時就已經創建好了實例,不管需不需要用。 2.懶漢式、不支持併發: 此模式只能運行在單線程下,在調用獲取實例的方法時才創建實例。 3.懶漢式、支持併發、synchronized: 4.雙重檢查鎖 、volatile(常用): 5.靜態私有內 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...