Exceptionless(二) - 使用進階

来源:https://www.cnblogs.com/markjiang7m2/archive/2019/06/29/11100563.html
-Advertisement-
Play Games

在上一篇文章Exceptionless - .Net Core開源日誌框架中就說到如何對Exceptionless進行本地化部署,不過我也跟大家說了,僅限於能用的階段。那今天我就繼續來探討一下如何再用好。 ...


Exceptionless(二) - 使用進階

作者:markjiang7m2
原文地址:https://www.cnblogs.com/markjiang7m2/p/11100563.html
官網地址:http://letyouknow.net

在上一篇文章Exceptionless - .Net Core開源日誌框架中就說到如何對Exceptionless進行本地化部署,不過我也跟大家說了,僅限於能用的階段。那今天我就繼續來探討一下如何再用好。

後臺運行服務

上次我就是直接通過腳本Start-ElasticSearch.ps1啟動ElasticSearch和Kibana服務,但是大家也能看到,服務是運行起來了,同時還有兩個命令視窗,如果一個不小心把視窗關閉了,服務也就關閉了,而且一旦伺服器重啟了,這兩個服務也不會自動啟動。
我這裡先暫時把Kibana扔一邊去,來看看ElasticSearch服務。ElasticSearch是直接有腳本支持將ElasticSearch安裝為Windows服務,在後臺運行。

less_23_searchservicebat

就是這個elasticsearch-service.bat腳本,支持一下參數:

  • install 將Elasticsearch作為服務安裝
  • remove 刪除已安裝的Elasticsearch服務(併在啟動時停止服務)
  • start 啟動Elasticsearch服務(如果已安裝)
  • stop 停止Elasticsearch服務(如果啟動)
  • manager 啟動一個GUI來管理已安裝的服務

安裝
命令行,進入到elasticsearch-service.bat所在的目錄,然後執行下麵的腳本

elasticsearch-service.bat install

啟動

less_25_servicestarted

這個時候我們可以直接在瀏覽器訪問9200埠看看服務是否正常

less_26_serviceconfirm

繼續使用上次部署好的Exceptionless
(如何使用IIS部署Exceptionless Web服務,請看Exceptionless - .Net Core開源日誌框架

因為我是直接用回之前ElasticSearch的節點,而且也沒有清空數據,所以可以直接用之前註冊的賬號重新登錄

less_27_weblogin

也是成功的,ElasticSearch服務已經運行在後臺了。

自動啟動
通過ElasticSearch提供的GUI可以將服務設置為自動啟動

elasticsearch-service.bat manager

Startup Type選擇為Automatic,再點擊OK保存

less_28_serviceauto

這樣,即使伺服器重啟了,我們的ElasticSearch服務也會自動啟動

其實,有玩過Windows服務的朋友一定知道,上面的一些操作在Windows自帶的服務管理器也能完成

同時按下"WIN+R" 打開服務的命令運行視窗。在服務運行視窗中輸入services.msc

在列表中也可以找到ElasticSearch服務,雙擊打開屬性視窗,跟剛剛的GUI操作就是一樣的了

less_29_windowsservice

再看Web.config

上次我只是改了Exceptionless的埠設置,其實這裡面還包含很多配置信息

<add name="RedisConnectionString" connectionString="localhost:6379,abortConnect=false" />
<add name="ElasticSearchConnectionString" connectionString="http://localhost:9200" />

官方是建議大家安裝和配置Redis,這樣就可以同時運行多個實例,並且重啟不會丟失狀態,強烈建議在Linux上運行Redis 3.0+版本,RedisConnectionString就是Redis的連接串

ElasticSearchConnectionString是必須的,指向ElasticSearch服務,如果有多個節點,則使用,隔開

<!-- Exceptionless Web 基礎Url -->
<add key="BaseURL" value="http://localhost:50001/#" />
<!-- 是否啟用ssl -->
<add key="EnableSSL" value="false" />
<!-- 
Dev: Use this mode when debugging. (Outbound emails will not be sent)
QA: Use this mode when deployed to staging. (Outbound emails restricted)
Production: Use this mode when deployed to production.
-->
<add key="WebsiteMode" value="Production" />
<!-- Controls whether users can signup. -->
<add key="EnableAccountCreation" value="true" />
<!-- Controls whether daily summary emails are sent -->
<add key="EnableDailySummary" value="true" />

網站模式WebsiteMode主要是限制郵件發送,預設值是Dev,不發送郵件,所以我這裡設置為Production

郵件發送配置,記得跟上面的WebsiteMode一起配置

<add key="SmtpHost" value="smtp.qq.com" />
<add key="SmtpPort" value="25" />
<add key="SmtpEncryption" value="SSL" />
<add key="SmtpUser" value="[email protected]" />
<add key="SmtpPassword" value="xxx" />

我在案例中使用的是自己的qq郵箱。我在qq郵箱中已經開啟了SMTP服務,並且也通過一個控制台應用程式測試可以發送郵件。
但是在Exceptionless這裡一樣的設置就是不行,在Web中點擊發送郵件,log記錄錯誤如下:
ERROR MailMessageJob Job run "MailMessageJob" failed: 由於意外的數據包格式,握手失敗。 System.IO.IOException: 由於意外的數據包格式,握手失敗。

清除Url
我們現在使用的Url都會帶有#!,例如

http://localhost:50001/#!/type/error/dashboard

可以按照下麵步驟清除字元#!

  • 首先保證你的IIS是否已經安裝了重寫模塊,可通過雙擊IIS中的模塊查看是否包含了RewriteModule
  • 更新Web.config文件
    • 釋放出在system.webServer中的rewrite節點
    • 刪除BaseURL值中的/#
    • 註釋了在system.webServer\modules中的<remove name="RewriteModule" />標簽
  • 修改app.config.77fc9ddd679d37dc.js文件中USE_HTML5_MODE的值為true

進程外運行作業
預設情況下,所有作業都在當前的Web進程中運行。如果發現事件處理開始變慢的時候,可以啟動並擴展多個作業實例。通過在進程外運行作業,可以確保所有作業是否正常運行。

  • 首先是要配置安裝Redis,這樣可以保證Exceptionless與作業之間能夠進行通信
  • 更新Web.config中的RunJobsInProcess值為false
  • 更新作業的配置,有兩種方法可選:
    • 使用環境變數進行配置Exceptionless。新增環境變數Exceptionless_{SETTING NAME} (例如: Exceptionless_BaseURL, Exceptionless_ElasticSearchConnectionString)。這是官方推薦的方法,因為它更簡單,而且當部署到azure時非常好用
    • 打開App_Data\jobs文件夾,然後按照在根目錄中Web.config的配置,再重新配置每個作業的xxx.exe.config
  • 在每個作業文件夾中都有一個run.bat文件,雙擊它就會運行這個作業。當然,也可以將這些作業全部設置為Windows服務在後臺運行

更多設置
除了上面提到的設置,Exceptionless還支持很多自定義配置,下麵是全部的設置列表,大家可根據自己的需要進行定製
列表按照這個格式進行排列:設置項 (數據類型,預設值)

EnableSSL (bool)
BaseURL (string)
InternalProjectId (string, "54b56e480ef9605a88a13153")
WebsiteMode (WebsiteMode, "Dev")
AppScope (string, String.Empty)
TestEmailAddress (string)
AllowedOutboundAddresses (List<string>, "exceptionless.io")
RunJobsInProcess (bool, true)
BotThrottleLimit (int, 25)
ApiThrottleLimit (int, Int32.MaxValue)
EventSubmissionDisabled (bool)
MaximumEventPostSize (long, 1000000)
MaximumRetentionDays (int, 180)
EnableDailySummary (bool)
MetricsServerName (string, "127.0.0.1")
MetricsServerPort (int, 8125)
EnableMetricsReporting (bool)
RedisConnectionString (string)
EnableRedis (bool)
DisableSnapshotJobs (bool)
DisableIndexConfiguration (bool)
ElasticSearchConnectionString (string)
ElasticSearchNumberOfShards (int, 1)
ElasticSearchNumberOfReplicas (int)
EnableElasticsearchTracing (bool)
LdapConnectionString (string)
EnableActiveDirectoryAuth (bool)
EnableSignalR (bool, true)
Version (string)
EnableIntercom (bool)
IntercomAppSecret (string)
EnableAccountCreation (bool, true)
MicrosoftAppId (string)
MicrosoftAppSecret (string)
FacebookAppId (string)
FacebookAppSecret (string)
GitHubAppId (string)
GitHubAppSecret (string)
GoogleAppId (string)
GoogleAppSecret (string)
GoogleGeocodingApiKey (string)
EnableBilling (bool)
StripeApiKey (string)
StorageFolder (string)
AzureStorageConnectionString (string)
EnableAzureStorage (bool)
BulkBatchSize (int, 1000)
SmtpHost (string)
SmtpPort (int, 587)
SmtpEnableSsl (bool, true)
SmtpUser (string)
SmtpPassword (string)

更多日誌類型

Exceptionless除了支持記錄Exception,也可以記錄LogMessage、Broken Links 、Feature Usages

LogMessage
LogMessage支持多種級別的日誌信息

  • Other
  • Trace
  • Debug
  • Info
  • Warn
  • Error
  • Fatal
  • Off

用法也很簡單,直接在你想要記錄日誌的地方直接加一句

ExceptionlessClient.Default.CreateLog("日誌信息", LogLevel.Debug).AddTags("tag1", "tag2").Submit();

所以我們在應用的過程中,可以添加一個統一的介面

public interface ILogger
{
    void Debug(string message, params string[] tags);
    void Error(string message, params string[] tags);
    void Fatal(string message, params string[] tags);
    void Info(string message, params string[] tags);
    void Off(string message, params string[] tags);
    void Other(string message, params string[] tags);
    void Trace(string message, params string[] tags);
    void Warn(string message, params string[] tags);
}
using Exceptionless;
using Exceptionless.Logging;
public class ExceptionlessLogger : ILogger
{
    public void Debug(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Debug).AddTags(tags).Submit();
    }

    public void Error(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Error).AddTags(tags).Submit();
    }

    public void Fatal(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Fatal).AddTags(tags).Submit();
    }

    public void Info(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Info).AddTags(tags).Submit();
    }

    public void Off(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Off).AddTags(tags).Submit();
    }

    public void Other(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Other).AddTags(tags).Submit();
    }

    public void Trace(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Trace).AddTags(tags).Submit();
    }

    public void Warn(string message, params string[] tags)
    {
        ExceptionlessClient.Default.CreateLog(message, LogLevel.Warn).AddTags(tags).Submit();
    }
}

然後在Startup.csConfigureServices方法註入ExceptionlessLogger

public void ConfigureServices(IServiceCollection services)
{
    services.AddSingleton<ILogger, ExceptionlessLogger>();
    services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
}

這樣就可以更方便地使用了

public class ValuesController : ControllerBase
{
    public ILogger _logger;
    public ValuesController(ILogger logger)
    {
        _logger = logger;
    }
    
    // GET api/values/{id}
    [HttpGet("{id}")]
    public ActionResult<string> Get(int id)
    {
        try
        {
            _logger.Info("Test msg", "tag1", "tag2");
            throw new Exception();
        }
        catch (Exception ex)
        {
            ex.ToExceptionless().AddTags("tag1", "tag2").Submit();
        }
        return $"value {id}";
    }
}

Broken Links
記錄404找不到請求的日誌

像我這裡沒有添加favicon.ico圖標,使用Chrome瀏覽器會自動請求這個資源,因此,Exceptionless就記錄了這樣的日誌

less_30_brokenlinks

也可以直接在Api服務中調用如下麵語句添加這種類型的日誌

ExceptionlessClient.Default.CreateNotFound("404 not found").SetType("404").SetSource($"api/values/{id}");

Feature Usages
類似的也可以添加Feature Usages日誌

ExceptionlessClient.Default.CreateFeatureUsage("Feature 1").SetSource($"api/values/{id}").SetType("FeatureType").Submit();

事件

上面所說的所有日誌類型,最終都會通過事件進行記錄,Exceptionless也支持我們直接記錄一個事件

例子如下:

var dataDic = new Exceptionless.Models.DataDictionary();
dataDic.Add("key", "value");
ExceptionlessClient.Default.SubmitEvent(new Exceptionless.Models.Event
{
    Count = 1,
    Date = DateTime.Now,
    Data = dataDic,
    Geo = "geo",
    Message = "message",
    ReferenceId = "referencelId",
    Source = "source",
    Tags = new Exceptionless.Models.TagSet() { "tags" },
    Type = "type"
});

Exceptionless同時也支持我們捕獲事件提交過程和事件提交後的事件,這樣我們就可以在過程中做一些操作,例如可以忽略404的請求,或者針對某些特殊日誌返回某些信息

為了代碼的整潔,可以將Exceptionless的配置單獨放到一個cs文件中

添加一個ExceptionlessBuilderExtensions

public static class ExceptionlessBuilderExtensions
{
    public static IApplicationBuilder UseExceptionless(this IApplicationBuilder app, IConfiguration configuration)
    {
        ExceptionlessClient.Default.Configuration.ApiKey = configuration["Exceptionless:ApiKey"];
        ExceptionlessClient.Default.Configuration.ServerUrl = configuration["Exceptionless:ServerUrl"];
        ExceptionlessClient.Default.SubmittingEvent += OnSubmittingEvent;
        app.UseExceptionless();

        return app;
    }

    private static void OnSubmittingEvent(object sender, EventSubmittingEventArgs e)
    {
        if (e.Event.IsNotFound())
        {
            e.Cancel = true;//取消事件提交
            return;
        }

        // 修改日誌信息
        if (e.Event.Source == "sourceA")
        {
            e.Event.AddTags("systemLog");
        }

        //TODO:
    }

    private static void OnSubmittedEvent(object sender, EventSubmittedEventArgs e)
    {
        // 做點什麼東西
        if (e.Event.Source == "sourceA")
        {
            //TODO:
        }
    }
}

然後修改Startup.cs

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    ……

    app.UseExceptionless(Configuration);

    ……
}

Exceptionless 日誌查詢

Exceptionless Web站點已經幫我們做好項目、時間、日誌類型的分類,大家可以很直觀地進行操作查詢。
我這裡要關註的是Filter查詢

前面記錄日誌的時候,有添加了tagType等信息,這時候就可以使用Filter進行查詢了。
語法:

[FilterType]:[value1] {or} {[value2]}

or是用於查詢多個該類型值的日誌時使用

例如:tag:tag1

less_32_filtertag

列幾個可能比較常用的

  • source:"my log source" or "my log source"
  • type:error
  • level:Error
  • ip:127.0.0.1

如果是要同時輸入多種類型的條件:

[FilterType]:[value] {OR|AND} {[FilterType]:[value]}

例如:tag:tag1 OR ip:127.0.0.1

更多的語法可以看官網說明
https://github.com/exceptionless/Exceptionless/wiki/Filtering-Searching

總結

在這篇文章中,我基本就是順著Exceptionless Self Hosting的介紹做了一遍,不過有一些東西因為沒有實際環境,所以也沒有去做,然後我這個也只是一個Demo,暫時也沒有做相關的壓力測試,所以也不知道這貨真正在生產環境大量用起來的時候會有一些什麼表現,會不會踩到什麼坑。歡迎大家在留言區跟我一起交流。今天就先跟大家介紹到這裡,希望大家能持續關註我們。

參考文獻
本文在編寫過程中引用或參考了以下文章中的部分內容,如有侵權,請聯繫修改或刪除。
https://www.cnblogs.com/edisonchou/p/exceptionless_deployment_on_production_env_introduction.html
https://www.cnblogs.com/ants/p/8580890.html


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

-Advertisement-
Play Games
更多相關文章
  • 1. 基礎知識 1.1 認識Lucene 維基百科的定義: Lucene是一套用於 全文檢索 和 搜索 的 開放源碼程式庫 ,由Apache軟體基金會支持和提供。Lucene提供了一個簡單卻強大的應用程式介面,能夠做全文索引和搜索,在Java開發環境里Lucene是一個成熟的免費開放源代碼工具;就其 ...
  • CyclicBarrier是什麼? CyclicBarrier具有什麼特性? CyclicBarrier與CountDownLatch的對比? ...
  • 第七章面向對象 1、面向過程編程 核心是”過程“二字,過程指的是解決問題的步驟,即先乾什麼再乾什麼 基於該思想編寫程式就好比在編寫一條流水線,是一種機械式的思維方式 優點:複雜的問題流程化、進而簡單化 ​ 缺點:可擴展性差 2、面向對象 核心”對象“二字,對象指的是特征(變數)與技能(函數)的結合體 ...
  • Zookeeper 從設計模式角度來看,是一個基於觀察者模式設計的分散式服務管理框架,它負責存儲和管理大家都關心的數據,然後接受觀察者的註冊,一旦這些數據的狀態發生變化,Zookeeper 就將負責通知已經在 Zookeeper 上註冊的那些觀察者做出相應的反應,從而實現集群中類似 Master/S... ...
  • 6.28自我總結 客戶端與伺服器之間文件傳輸斷電續傳 `通過判斷文件大小,以及文件在讀取中的指針位置的調整來解決斷電續傳問題' 1.程式目錄 2.程式思路 第一步:我們什麼都不懂,但是有幾個模塊肯定會有一個是conf中的setting來存一些常量 第二步:我們也需要一個db文件來存內容 第三步:我們 ...
  • 定義 用原型實例指定創建對象的種類,並且通過複製這些原型創建新的對象。 類圖如下: 原型模式涉及3個角色。 客戶(Client)角色:該角色提出創建對象的請求。 抽象原型(Prototype)角色:該角色是一個抽象角色,通常由一個Java介面或抽象類實現,給出所有的具體原型類所需要的介面。 具體原型 ...
  • 性能分析工具小試 1. perf sudo yum install perf* 註:這個也可以用源碼安裝,比如我系統目錄:/usr/src/kernels/3.10.0-862.el7.x86_64/tools/perf 這裡邊直接帶有perf 首先編譯debug版程式,比如編譯了test程式,然後 ...
  • 先做個自我介紹,我13年考上一所很爛專科民辦的學校,學的是生物專業,具體的學校名稱我就不說出來獻醜了。13年我就輟學了,我在那樣的學校,一年學費要1萬多,但是根本沒有人學習,我實在看不到希望,我就退學了。退學後我也迷茫,大專都沒有畢業,我真的不知道我能幹什麼,我在糾結著我能做什麼。所以輟學後我一段時 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...