開源日誌框架Exceptionless使用教程

来源:https://www.cnblogs.com/youring2/archive/2019/09/19/11546485.html
-Advertisement-
Play Games

Exceptionless是一款日誌記錄框架,它開源、免費、提供管理界面、易於安裝和使用。ExceptionLess底層採用ElasticSearch作為日誌存儲,提供了快速、豐富的查詢API,方便我們進行系統集成。本文將介紹ExceptionLess的常見用法。 安裝ExceptionLess 在 ...


Exceptionless是一款日誌記錄框架,它開源、免費、提供管理界面、易於安裝和使用。ExceptionLess底層採用ElasticSearch作為日誌存儲,提供了快速、豐富的查詢API,方便我們進行系統集成。本文將介紹ExceptionLess的常見用法。

安裝ExceptionLess

在ExceptionLess官網提供了基於Docker的私有化部署方式,我們可以按照官網的方式進行測試環境的安裝。

  1. 在官網github中下載最新的release包,地址:https://github.com/exceptionless/Exceptionless/releases
  2. 解壓縮,然後進入解壓縮的目錄,執行 docker-compose up -d命令在後臺啟動多個容器,當執行完成後,Exceptionless已經在本地運行起來了。我們可以在Kitematic中查看運行中的容器
  3. 按照官網的說明,5000埠是登陸頁面,但實際情況是5000是API,5100才是登陸頁面,因此我們打開http://localhost:5100進入登陸頁面。註意:此處可能跟版本有關,在使用時查看docker的埠映射。

通過以上步驟,就在本地搭建好了測試環境。我們可以看到啟動的總共啟動了6個容器,分別是redis、elasticsearch、kibana、Exceptionless Job、Exceptionless Api、Excetpionless UI。

快速上手

搭建好測試環境後,首先訪問Exceptionless UI來創建用戶、組織和項目。然後,當項目創建完成之後,Exceptionless 會跳轉到客戶端配置頁面,來指引我們如何使用Exceptionless客戶端。我們可以選擇自己需要用到的客戶端,通過頁面的指引完成客戶端配置。

引導頁面如下:

image

按照這種方式我們可以完成.Net平臺項目、JS項目的配置。

客戶端API:https://github.com/exceptionless/Exceptionless.Net/wiki

配置好以後,我們就可以記錄日誌了,例如(代碼來源於官網):

// Import the exceptionless namespace.
using Exceptionless;

// Submit logs
ExceptionlessClient.Default.SubmitLog("Logging made easy");

// You can also specify the log source and log level.
// We recommend specifying one of the following log levels: Trace, Debug, Info, Warn, Error
ExceptionlessClient.Default.SubmitLog(typeof(Program).FullName, "This is so easy", "Info");
ExceptionlessClient.Default.CreateLog(typeof(Program).FullName, "This is so easy", "Info").AddTags("Exceptionless").Submit();

// Submit feature usages
ExceptionlessClient.Default.SubmitFeatureUsage("MyFeature");
ExceptionlessClient.Default.CreateFeatureUsage("MyFeature").AddTags("Exceptionless").Submit();

// Submit a 404
ExceptionlessClient.Default.SubmitNotFound("/somepage");
ExceptionlessClient.Default.CreateNotFound("/somepage").AddTags("Exceptionless").Submit();

// Submit a custom event type
ExceptionlessClient.Default.SubmitEvent(new Event { Message = "Low Fuel", Type = "racecar", Source = "Fuel System" });

功能介紹

Exceptionless中的事件有以下幾種類型:

  • 日誌消息:記錄的日誌,可以是任何文本內容
  • 特性使用:功能使用量的記錄,例如介面調用情況等
  • 異常情況:記錄異常的信息
  • 失效鏈接:當被訪問的頁面不存在時進行記錄

除了記錄內容外,Exceptionless還支持對事件添加標簽、附加數據、用戶描述等操作,例如(代碼來源於官網):

try {
    throw new ApplicationException("Unable to create order from quote.");
} catch (Exception ex) {
    ex.ToExceptionless()
        // Set the reference id of the event so we can search for it later (reference:id).
        // This will automatically be populated if you call ExceptionlessClient.Default.Configuration.UseReferenceIds();
        .SetReferenceId(Guid.NewGuid().ToString("N"))
        // Add the order object but exclude the credit number property.
        .AddObject(order, "Order", excludedPropertyNames: new [] { "CreditCardNumber" }, maxDepth: 2)
        // Set the quote number.
        .SetProperty("Quote", 123)
        // Add an order tag.
        .AddTags("Order")
        // Mark critical.
        .MarkAsCritical()
        // Set the coordinates of the end user.
        .SetGeo(43.595089, -88.444602)
        // Set the user id that is in our system and provide a friendly name.
        .SetUserIdentity(user.Id, user.FullName)
        // Set the users description of the error.
        .SetUserDescription(user.EmailAddress, "I tried creating an order from my saved quote.")
        // Submit the event.
        .Submit();
}

NLog、Log4net集成

官方支持NLog、Log4net集成的支持,只需要添加相應的日誌組件的配置文件即可。以Log4net為例:

首先添加程式集的支持:

Install-Package Exceptionless.Log4net

然後在log4net的配置文件中進行配置(代碼來源於官網):

<log4net>
<appender name="exceptionless" type="Exceptionless.Log4net.ExceptionlessAppender,Exceptionless.Log4net">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%-4timestamp [%thread] %-5level %logger %ndc - %message%newline"/>
  </layout>
</appender>

<root>
  <level value="DEBUG"/>
  <appender-ref ref="exceptionless"/>
</root>
</log4net>

API介面

除了豐富的客戶端功能外,Exceptionless還提供了大量API的支持,這些API可以在5000埠訪問到。地址為:http://localhost:5000/docs/index.html,截圖如下

image

通過這些介面,我們可以實現更多自定義的操作,例如用戶授權、項目管理、日誌查詢等操作。

參考資料

我的博客即將同步至騰訊雲+社區,邀請大家一同入駐:https://cloud.tencent.com/developer/support-plan?invite_code=3mb9ch11jjy8o


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

-Advertisement-
Play Games
更多相關文章
  • 在實際的開發中,我們會遇到許多重覆頁面的部分,這些頁面的重覆會讓我們的代碼看起來非常冗餘 所以我們要進行頁面的佈局規劃。思路:將頁面中的公有部分取出來作為單獨的頁面,其他繼承公共模板 在公共模板的基礎上替換占位符內容從而構成新的內容頁面。 @頁面占位符yield和頁面繼承extends 1.使用占位 ...
  • centos7上安裝zookeeper 1 準備工作 1、準備伺服器,本次安裝採用 centos7系統、記憶體2G、存儲60G的虛擬機伺服器一臺; 2、伺服器安裝java環境: 參考文章《centos7上安裝jdk8》博文; 3、準備zookeeper安裝包, 本次採用 zookeeper 3.4.1 ...
  • 前面已經學習了服務註冊與發現組件,負載均衡組件,這樣我們的微服務系統已經可以使用了。為了保證其高可用,單個服務通常會集群部署。由於網路原因或者自身的原因,服務並不能保證 100% 可用,如果單個服務出現問題,調用這個服務就會出現線程阻塞,此時若有大量的請求涌入,Servlet 容器的線程資源會被消耗 ...
  • 1. 安裝 Namesrv 拉取鏡像 docker pull rocketmqinc/rocketmq:4.4.0` docker run d p 9876:9876 v {RmHome}/data/namesrv/logs:/root/logs v {RmHome}/data/namesrv/st ...
  • 面試題 redis 的過期策略都有哪些?記憶體淘汰機制都有哪些?手寫一下 LRU 代碼實現? 面試官心理分析 如果你連這個問題都不知道,上來就懵了,回答不出來,那線上你寫代碼的時候,想當然的認為寫進 redis 的數據就一定會存在,後面導致系統各種 bug,誰來負責? 常見的有兩個問題: 往 redi ...
  • 之前都是用Eclipse,今天試了下IntelliJ IDEA,搭建了一個Spring Boot 2的Hello world項目。 ...
  • 一.if語句 1.if語句 作用:讓程式根據條件選擇性地執行某條語句或某些語句 說明:if語句又叫條件語句,也叫分支語句 語法: 語法說明: elif子句可以有0個,1個或多個 else子句可以有0個或1個且只能放在此if語句的最後 要求:if語句內部的語句通常要以4個空格的縮進來表示包含關係,相同 ...
  • 1.首先在你的路由文件定義好訪問的路徑 2. ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...