首页 > Windows开发 > 详细

C#添加程序执行时长监控日志

时间:2021-07-20 10:50:14      阅读:35      评论:0      收藏:0      [点我收藏+]
/// <summary>
/// C#添加程序执行时长监控日志
/// </summary>
public class StopwatchLog
{
    static Task write;
    static List<string> Logs = new List<string>();
    static StopwatchLog()
    {
        write = Task.Run(() =>
        {
            while (true)
            {
                try
                {
                    Thread.Sleep(2000);
                    var logs = Logs;
                    Logs = new List<string>();
                    string file = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "timewatch.log");
                    File.AppendAllLines(file, logs);
                }
                catch { }
            }
        });
    }

    /// <summary>
    /// 初始化请求
    /// </summary>
    public static void Start()
    {
        HttpContext.Current.Items["request"] = DateTime.Now.ToUniversalTime().Ticks.ToString();
    }

    /// <summary>
    /// 开始记录点
    /// </summary>
    /// <returns></returns>
    public static Stopwatch StartLog()
    {
        Stopwatch stopwatch = new Stopwatch();
        stopwatch.Start();
        return stopwatch;
    }

    /// <summary>
    /// 结束记录点
    /// </summary>
    /// <param name="stopwatch"></param>
    /// <param name="point"></param>
    public static void EndLog(Stopwatch stopwatch, string tag = "")
    {
        stopwatch.Stop();

        //当前堆栈信息
        StackTrace st = new StackTrace();
        StackFrame[] sfs = st.GetFrames();
        //过虑的方法名称,以下方法将不会出现在返回的方法调用列表中
        string _filterdName = "ResponseWrite,ResponseWriteError,";
        string _fullName = string.Empty;
        for (int i = 1; i < sfs.Length; ++i)
        {
            //非用户代码,系统方法及后面的都是系统调用,不获取用户代码调用结束
            if (StackFrame.OFFSET_UNKNOWN == sfs[i].GetILOffset()) break;
            string _methodName = sfs[i].GetMethod().Name;
            if (_filterdName.Contains(_methodName)) continue;
            _fullName = _methodName + "-" + _fullName;
        }

        _fullName = string.IsNullOrEmpty(tag) ? _fullName.TrimEnd(-) : _fullName + tag;

        var request = Convert.ToString(HttpContext.Current.Items["request"]);
        var log = $"{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")},{request},{_fullName},{stopwatch.ElapsedMilliseconds}";
        Logs.Add(log);
    }
}

 

C#添加程序执行时长监控日志

原文:https://www.cnblogs.com/chenyinxin/p/15033159.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!