實時監控Cat之旅~對請求是否正常結束做監控(分散式的消息樹)

来源:http://www.cnblogs.com/lori/archive/2016/03/25/5318695.html
-Advertisement-
Play Games

對基於請求的分散式消息樹的分析 在MVC時有過濾器System.Web.Mvc.ActionFilterAttribute,它可以對action執行的整個過程進行攔截,執行前與執行後我們可以註入自己的代碼,這是我們實現對請求做監控的前提,對於一個請求來說,如果它是從Get或者Post過來的,我們會在 ...


對基於請求的分散式消息樹的分析

在MVC時有過濾器System.Web.Mvc.ActionFilterAttribute,它可以對action執行的整個過程進行攔截,執行前與執行後我們可以註入自己的代碼,這是我們實現對請求做監控的前提,對於一個請求來說,如果它是從Get或者Post過來的,我們會在發起端將初始catContext進行鏈條式的傳遞,從第一個節點開始生成並傳遞,最後到尾結節,開始執行cat,生成新的context,將新的context回寫到響應頭,由上一個節點拿到這個響應頭,開始寫自己的cat,這個過程最後執行到第一個節點,整個過程結束!

對消息樹流程的設計

代碼的實現

下麵開始設計咱們的Filter攔截器,用來生成catContext,並將處理後的context寫響應頭中

   /// <summary>
    /// Cat攔截器,主要攔截Http請求
    /// </summary>
    public class CatFilter : System.Web.Mvc.ActionFilterAttribute
    {
        /// <summary>
        /// 請求來到時
        /// </summary>
        /// <param name="filterContext"></param>
        public override void OnActionExecuting(System.Web.Mvc.ActionExecutingContext filterContext)
        {
            base.OnActionExecuting(filterContext);
        }

        /// <summary>
        /// 請求結束時
        /// 調用次序:A->B->C->c->b->a,從c開始執行,把context結果在響應頭裡依據向回傳
        /// </summary>
        /// <param name="filterContext"></param>
        public override void OnActionExecuted(System.Web.Mvc.ActionExecutedContext filterContext)
        {


            var context = PureCat.CatClient.GetCatContextFromServer();
            if (context != null)
            {

                context = PureCat.CatClient.DoTransaction("youDomain", filterContext.HttpContext.Request.Url.AbsoluteUri, () =>
                {
                    PureCat.CatClient.LogRemoteCallServer(context);

                    PureCat.CatClient.LogEvent(filterContext.HttpContext.Request.Url.AbsoluteUri, "Action  Finish...");

                    if (filterContext.Exception != null)
                    {
                        PureCat.CatClient.LogError(filterContext.Exception);
                    }
                });

                #region 響應頭寫數據
                if (filterContext.HttpContext.Response.Headers.GetValues("catContext") != null
                    && filterContext.HttpContext.Response.Headers.GetValues("catContext").Length > 0)
                {
                    filterContext.HttpContext.Response.Headers.Remove("catContext");
                }
                filterContext.HttpContext.Response.Headers.Add("catContext", Lind.DDD.Utils.SerializeMemoryHelper.SerializeToJson(context));

                #endregion
            }

            base.OnActionExecuted(filterContext);

        }
    }

最後就是修改我們之前封裝的GET和POST方法,讓它處理一下響應頭,使用響應頭的context作為當前cat的上下文

  /// <summary>
        /// Get數據
        /// </summary>
        /// <param name="requestUri"></param>
        /// <returns></returns>
        public static HttpResponseMessage Get(string requestUri, bool isCat)
        {
            var handler = new HttpClientHandler() { };
            using (var http = new HttpClient(handler))
            {
                PureCat.CatClient.SetCatContextToServer(http, GetCurrentContext("Get Request Sent...", isCat));//設置介面api的頭,發送
                var response = http.GetAsync(requestUri).Result;
                var context = response.Headers.Where(i => i.Key == "catContext");
                if (context != null && context.Count() > 0)
                {
                    var cat = Lind.DDD.Utils.SerializeMemoryHelper.DeserializeFromJson<CatContext>(context.First().Value.FirstOrDefault());
                    PureCat.CatClient.SetCatContextToServer(System.Web.HttpContext.Current, cat);
                }
                return response;
            }
        }

日誌的生成

最後生成的cat日誌也是我們可以理解的,即從a,b,c,d的調用,在執行結束的監控順序是d,c,b,a,呵呵,並且在在step2時故意放了一個異常出來,讓cat記錄一下,呵呵。

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

-Advertisement-
Play Games
更多相關文章
  • 本文內容全部出自《Python基礎教程》第二版,在此分享自己的學習之路。 lxx___歡迎轉載:http://www.cnblogs.com/Marlowes/p/5312236.htmllxx___ Created on Xu Hoo 讀者已經知道了什麼是字元串,也知道如何創建它們。利用索引和分片 ...
  • 本人大一狗,內容僅為個人的初體會,有誤之處請見諒。 初學者可能剛接觸一些新名詞會感覺好像很厲害的樣子,有種不明覺厲的樣子。 比如多態,泛型,繼承,介面。其實這些也並不是很難,不要被名字所嚇到,不用怕,慢慢就會理解他了。 講一下多態,我認為多態是建立在繼承的基礎之上的。 我們想看看繼承。 這裡我們用了 ...
  • The Zen of Python, by Tim Peters Beautiful is better than ugly.Explicit is better than implicit.Simple is better than complex.Complex is better than c ...
  • 一、前言 本文主要測試redis實現session共用的實現方式,不討論如何讓nginx參與實現負載均衡等。 二、環境配置 本測試在Window下進行 三、安裝tomcat-redis-session-manager插件 1.源碼下載: 最新版源碼對jdk版本有要求,必須是JDk1.7,否則編譯通不 ...
  • Python的函數除了正常使用的必選參數外,還可以使用預設參數、可變參數和關鍵字參數。 預設參數 基本使用 預設參數就是可以給特定的參數設置一個預設值,調用函數時,有預設值得參數可以不進行賦值,如: 這樣調用power(5)時,相當於調用power(5, 2)。 設置預設參數時的註意事項: 一是必選 ...
  • Java實現數組排序 ...
  • 一、親密性原則 將相關的內容組織到一起,通過字體大小,留白分層等區分內容關係 改變成 如果通過間距就可以劃分區域,我們就不用線條,框架去劃分區域,這樣更加簡潔 改變成 註:1、透明度的改變:增強背景融合性與親密性 2、方向性:有指向的線條(色塊的利用可以產生視覺衝擊) 3、顏色:不要使用純黑色(可以 ...
  • 建造者模式(Builder) 類圖 描述 建造者: Builder:定義一個建造者抽象類,以規範產品對象的各個組成部分的建造。這個介面規定要實現對象的哪些部分的創建,並不涉及具體的對象部件的創建。 ConcreteBuilder:繼承Builder,針對不同的業務邏輯,具體化對象的各部分的創建。在建 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...