Используйте MiniProfiler для захвата медленных запросов

Я хочу использовать MiniProfiler для вызова функции по истечении установленного срока. Так настроен MiniProfiler. После этого я включил скрипт профилирования, который мы используем для профилирования того, что требует профилирования. Моя проблема заключается в создании какого-либо промежуточного программного обеспечения, которое может перехватывать этот вызов "MiniProfiler.Current.Step", когда время превышает 1000 мс.

        app.UseMiniProfiler(new MiniProfilerOptions
        {
            ResultsAuthorize = x => false,
            ResultsListAuthorize = x => false,
            Storage = new SqlServerStorage(Configuration.GetConnectionString("MiniProfiler"))
        });
        MiniProfilerEF6.Initialize();

        app.Use(async (context, next) =>
        {
            MiniProfiler.Current.Name = context.Request.GetDisplayUrl();
            await next.Invoke();
        });

    /// <summary>
    /// The main profiler, useage:
    /// using(this.Profile("more context"))
    /// {
    ///     Do things that needs profiling, and you may nest it.
    /// }
    /// </summary>
    /// <param name="profiled">The object that is profiled</param>
    /// <param name="subSectionName">More context for the output result</param>
    /// <param name="methodName">Possible override for the method name called</param>
    /// <param name="profiledTypeName">Possible override for the profiled type</param>
    /// <returns>An IDisposable, to help with scoping</returns>
    public static IDisposable Profile(this object profiled,
                                      string subSectionName = null,
                                      [CallerMemberName] string methodName = "",
                                      string profiledTypeName = null)
    {
        if (profiled == null)
            throw new ArgumentNullException(nameof(profiled));

        var profiledType = profiledTypeName ?? profiled.GetType().Name;
        return Profile(methodName, profiledType, subSectionName);
    }


    public static IDisposable Profile(string methodName,
                                      string profiledTypeName,
                                      string subSectionName = null)
    {
        var name = subSectionName != null
            ? $"{profiledTypeName}.{methodName}:{subSectionName}"
            : $"{profiledTypeName}.{methodName}";

        return MiniProfiler.Current?.Step(name);
    }

0 ответов

Другие вопросы по тегам