TomatoLog-1.1.0實現ILoggerFactory

来源:https://www.cnblogs.com/viter/archive/2019/08/27/11418366.html
-Advertisement-
Play Games

客戶端實現了ILoggerFactory,使用服務註入成功後即可使用,對業務入侵非常小,也支持通過客戶端調用寫入日誌流。 ...


TomatoLog

TomatoLog 是一個基於 .NETCore 平臺的產品。

The TomatoLog 是一個中間件,包含客戶端、服務端,非常容易使用和部署。

客戶端實現了ILoggerFactory,使用服務註入成功後即可使用,對業務入侵非常小,也支持通過客戶端調用寫入日誌流。

TomatoLog 的客戶端和服務端目前都是基於 .NETCore 版本,客戶端提供了三種日誌流傳輸方式,目前實現了 Redis/RabbitMQ/Kafka 流。如果希望使用非 .NETCore 平臺的客戶端,你可以自己開放其它第三方語言的客戶端,通過實現 TomatoLog 傳輸協議,將數據傳送到管道(Redis/RabbitMQ/Kafka)中即可。

TomatoLog 服務端還提供了三種存儲日誌的方式,分別是 File、MongoDB、Elasticsearch,存儲方式可以通過配置文件指定。在 TomatoLog 服務端,我們還提供了一個Web 控制台,通過該控制台,可以對日誌進行查詢、搜索,對服務過濾器進行配置,警報配置、通知發送等等,其中,可使用的警報通知方式有:SMS 和 Email 兩種方式,但是,SMS 其本質是一個 Http 請求,通過 SMS 的配置,可以實現向所有提供了 Http 介面的網關發送通知。

TomatoLog 系統架構

Get Started

使用客戶端

選擇安裝以下客戶端中的任意一項

Install-Package TomatoLog.Client.Redis
Install-Package TomatoLog.Client.RabbitMQ
Install-Package TomatoLog.Client.Kafka

TomatoLog客戶端配置文件 appsetting.json

{
  "TomatoLog": {
    "LogLevel": "Information",
    "ProjectLabel": "Example",
    "ProjectName": "Example",
    "SysOptions": {
      "EventId": true,
      "IP": true,
      "IPList": true,
      "MachineName": true,
      "ProcessId": true,
      "ProcessName": true,
      "ThreadId": true,
      "Timestamp": true,
      "UserName": true
    },
    "Tags": null,
    "Version": "1.0.0",
    "Exchange": "TomatoLog-Exchange",
    "ExchangeType": "direct",
    "Host": "127.0.0.1",
    "Password": "123456",
    "Port": 5672,
    "QueueName": "TomatoLog-Queue",
    "RouteKey": "All",
    "UserName": "lgx",
    "vHost": "TomatoLog"
  }
}

服務註入

public void ConfigureServices(IServiceCollection services)
{
    services.AddSingleton<ITomatoLogClient>(factory =>
    {
        var options = this.Configuration.GetSection("TomatoLog").Get<EventRabbitMQOptions>();
        var client = new TomatoLogClientRabbitMQ(options);

        return client;
    });
    ...
}

配置啟用

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory factory, ITomatoLogClient logClient)
{
    factory.UseTomatoLogger(logClient);
    ...
}

使用 TomatoLogClient

[Route("api/[controller]")]
[ApiController]
public class HomeController : ControllerBase
{
    private readonly ITomatoLogClient logClient;
    private readonly ILogger logger;
    public HomeController(ILogger<HomeController> logger, ITomatoLogClient logClient)
    {
        this.logger = logger;
        this.logClient = logClient;
    }

    [HttpGet]
    public async Task<ActionResult<IEnumerable<string>>> Get()
    {
        // Used by ILogger
        this.logger.LogError("測試出錯了");

        // Used By ITomatoLogClient
        try
        {
            await this.logClient.WriteLogAsync(1029, LogLevel.Warning, "Warning Infomation", "Warning Content", new { LastTime = DateTime.Now, Tips = "Warning" });
            throw new NotSupportedException("NotSupported Media Type");
        }
        catch (Exception ex)
        {
            await ex.AddTomatoLogAsync();
        }

        return new string[] { "value1", "value2" };
    }
}

部署服務端

首先,下載服務端壓縮包文件 版本預覽 ,該壓縮包僅包含項目運行必需文件,托管該服務端的伺服器上必須按照 DotNET Core SDK 2.2+

接下來,解壓文件,修改 appsetting.Environment.json 文件將伺服器進行配置,將配置好的服務端部署到你的伺服器上,可以為 TomatoLog 選擇 IIS 或者其它托管方式,服務端預設運行埠為:20272.

編輯服務端配置文件

{
  "Logging": {
    "IncludeScopes": false,
    "LogLevel": {
      "Default": "Debug",
      "System": "Information",
      "Microsoft": "Information"
    }
  },
  "TomatoLog": {
    "Cache-Redis": null, // 過濾器會使用該分散式緩存進行策略考量,如果有配置
    "Config": {
      "SysConfig": "Config/SysConfig.json" // 系統配置文件,可通過Web控制台進行配置
    },
    "Storage": {
      "Type": "ToFile", //ToFile/ToES/ToMongoDB 可以選擇的存儲方式
      "File": "D:\\TomatoLog\\Storage", // 如果Type選擇了 ToFile ,則這裡必須指定絕對路徑
      "ES": "http://127.0.0.1:9200/", // 如果Type選擇了ToES,這裡必須配置 Elasticsearch 服務地址
      "MongoDB": "mongodb://root:[email protected]:27017/admin" //如果Type選擇了ToMongoDB,這裡必須配置 ToMongoDB 資料庫鏈接
    },
    "Flow": {
      "Type": "RabbitMQ", // Redis/RabbitMQ/Kafaka 這裡指定客戶端和伺服器的傳輸管道類型,兩端配置必須一致
      "Redis": {
        "Connection": null,
        "Channel": "TomatoLogChannel"
      },
      "RabbitMQ": { // 如果使用了 RabbitMQ,則必須配置該節點
        "Host": "127.0.0.1",
        "Port": 5672,
        "UserName": "root",
        "Password": "123456",
        "vHost": "TomatoLog",
        "Exchange": "TomatoLog-Exchange",
        "ExchangeType": "direct",
        "QueueName": "TomatoLog-Queue",
        "RouteKey": "All",
        "Channels": 1 // 運行的消息隊列實例數量
      },
      "Kafka": {
        "Group": "TomatoLogServer",
        "BootstrapServers": "127.0.0.1:9092",
        "Topic": "TomatoLog"
      }
    }
  }
}

番茄日誌服務端控制台長什麼樣

在瀏覽器中打開地址:http://localhost:20272/

首頁看日誌列表

日誌詳情、彈出查看詳情、日誌搜索、支持ES/MongoDB/File搜索

全局日誌處理、警報配置

針對單個項目的詳細日誌處理、警報配置

一次打包,到處運行

不管是從項目結構還是解決方案,我都強調簡單就是最美的根本要求,解決方案的內容雖然看起來很多,但是你也只需要按需引用其中一個客戶端就可以了,服務端更是如此,全站都打包在一個 .NETCore 的應用程式中,程式的警報配置都是存儲在配置文件中的,無需資料庫支持。


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

-Advertisement-
Play Games
更多相關文章
  • httpApplication調用ProcessRequest方法,內部執行19個管道事件,如下 BeginRequest 開始處理請求 AuthenticateRequest 授權驗證請求開始,獲取用戶授權信息 PostAuthenticateRequest 獲取成功 AunthorizeRequ ...
  • 原標題:自動駕駛世界賽道迎來“中國時間” 25日,在“山城”重慶近40攝氏度的高溫下,31輛裝載了激光雷達、相機、衛星導航系統的自動駕駛汽車接受了主動超車、駝峰橋、禮讓行人等15個複雜交通場景的考驗,接下來幾天還將接受“大考”——在高速公路上行駛。 在2019中國國際智能產業博覽會(簡稱“智博會”) ...
  • 1. 什麼是滾動輪劫持 這篇文章介紹一個很簡單的繼承自ScrollViewer的控制項: 所有代碼就這麼多,這個ExtendedScrollViewer 只是用來解決滾動輪劫持(scroll wheel hijack)的問題。所謂的滾動輪劫持,簡單來說即是在一個可以滾動的頁面使用滑鼠滾輪滾動頁面的過程 ...
  • 場景 使用NPOI導入Excel並賦值給DataTable,然後顯示在DataGrdView上,並且添加多選框,然後獲取選中行的內容。 Winform中使用NPOI實現Excel導入並賦值給DataTable: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/ar ...
  • lambda: linq: 發現木有,linq 後面還是用了 lambda,我沒找到linq 中類似取 top1 的方法, 功能上感覺linq要少一些,但是涉及到多表聯查的時候,那真的是linq看起來更清晰,而lambda的話可能會把你搞亂。 比如:(這是純 lambda,經測試是正確的聯查 ) 但 ...
  • 由於最近在做wpf版的截圖軟體,在處理全局熱鍵的時候,發現國內博客使用的都是winform窗體的鍵盤處理方式,此方式需要使用winform的動態庫,如此不協調的代碼讓我開始在github中尋找相關代碼。 最終,我找到了,wpf本身就支持處理系統的鍵盤消息(包括熱鍵)。 使用ComponentDisp ...
  • 近兩天項目中需要添加一個功能,是根據攝像頭來讀取二維碼信息,然後根據讀出來的信息來和資料庫中進行對比顯示數據。 選擇技術Zxing、WPFMediaKit。基本的原理就是讓WPFmediaKit來對攝像頭進行操作,然後Zxing這個庫對圖片進行分析大致就是這樣。 在後臺中定義了定時器,用於解析當前攝 ...
  • 前面介紹了單元測試的框架NUnit,它可以很好的幫助我們建立測試,檢驗我們的代碼是否正確。但這還不夠,有時候我們的業務比較重,會依賴其它的類。基於隔離測試的原則,我們不希望依賴的其它類影響到我們的測試目標。這時候Mock就顯得十分重要了。當然還有其它因素使得我們必須Mock對象,比如配置文件,DB等 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...