安装

我们可以使用Nuget来下载这个包。

PM> Install-Package MiniProfiler.AspNetCore.Mvc

配置Startup.cs

MiniProfiler配置起来很简单,只需要以下几步

ConfigureServices方法中添加MiniProfiler服务

public void ConfigureServices(IServiceCollection services)
{services.AddMiniProfiler(options =>options.RouteBasePath = "/profiler");
}
  • 这里是配置了MiniProfiler的路由基础路径,默认的路径是/mini-profiler-resources
  • 按照当前配置,你可以使用"/profiler/results"来访问分析报告

激活中间件,启用MiniProfiler服务

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) { app.UseMiniProfiler(); }

配置需要监控分析的代码

public class ValueController : ControllerBase
{[HttpGet] public IEnumerable<string> Get() { string url1 = string.Empty; string url2 = string.Empty; using (MiniProfiler.Current.Step("Get方法")) { using (MiniProfiler.Current.Step("准备数据")) { using (MiniProfiler.Current.CustomTiming("SQL", "SELECT * FROM Config")) { // 模拟一个SQL查询 Thread.Sleep(500); url1 = "https://www.baidu.com"; url2 = "https://www.sina.com.cn/"; } } using (MiniProfiler.Current.Step("使用从数据库中查询的数据,进行Http请求")) { using (MiniProfiler.Current.CustomTiming("HTTP", "GET " + url1)) { var client = new WebClient(); var reply = client.DownloadString(url1); } using (MiniProfiler.Current.CustomTiming("HTTP", "GET " + url2)) { var client = new WebClient(); var reply = client.DownloadString(url2); } } } return new string[] { "value1", "value2" }; } }

代码解释:

  • MiniProfiler.Current.Step方法定义了分析的步骤,这个方法可以接受一个String类型的参数,它会显示在最终的报告中
  • MiniProfiler.Current.CustomTiming方法是更细粒度的对报告内容进行分类,以上代码中定义了2种分类,一种是SQL, 一种是Http
  • 上述程序的功能: 模拟从数据库拉取2个网站的Url, 并使用WebClient来分别请求网站的Url

查看效果

下面我们启动项目, 项目默认打开/api/values

然后我们来访问以下/profiler/results, 就会出现如下页面

如上图所示,我们可以很清楚的看到代码中每一部分的耗时,由于我们添加了2种分类SQL和Http,所以列表中会对2种分类进行汇总。

重点: 当前页面只会显示最近的一次请求

从当前报告中可以得到以下结论

  • 当前请求总响应时间 1723.6ms
  • SQL语句查询耗时517.ms
  • 2次Http请求共耗时868.3ms, 其中访问百度耗时424.6ms, 访问新浪耗时443.7ms

如何让MiniProfiler与Swagger集成

这里我们就不再讲如何在ASP.NET Core中整合Swagger。

MiniProfiler和Swagger是可以集成在一起的,为了完成这个功能,我们需要进行以下几步

下载Swagger自定义页面

默认的index.html页面可以从如下链接下载

https://github.com/domaindrivendev/Swashbuckle.AspNetCore/blob/master/src/Swashbuckle.AspNetCore.SwaggerUI/index.html

下载之后将这个文件放置到项目根目录下。

接下来我们需要在这个文件的头部加入如下脚本代码:

<script async="async" id="mini-profiler" src="/profiler/includes.min.js?v=4.0.138+gcc91adf599" data-version="4.0.138+gcc91adf599" data-path="/profiler/" data-current-id="4ec7c742-49d4-4eaf-8281-3c1e0efa748a" data-ids="" data-position="Left" data-authorized="true" data-max-traces="15" data-toggle-shortcut="Alt+P" data-trivial-milliseconds="2.0" data-ignored-duplicate-execute-types="Open,OpenAsync,Close,CloseAsync"></script>

最后我们需要配置这个index.html文件的Bulid Action为Embedded resource

安装自定义页面

Startup.cs文件中,我们需要修改UseSwaggerUI中间件的配置,这里我们需要添加一个InputStream配置。

app.UseSwaggerUI(c =>
{c.RoutePrefix = "swagger";c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1"); c.IndexStream = () => GetType().GetTypeInfo().Assembly.GetManifestResourceStream("MiniProfilerSample.index.html"); });

注意:这里MiniProfilerSample是项目的命名空间名

最终效果

重新启动项目,Swagger文档页面的左上角就出现了一个小的面板,当模拟请求一个连接之后,它就会显示出当前请求的分析数据,看起来是不是很酷炫。

总结

本篇博客描述了如何使用MiniProfiler来监控分析你的Api。 MiniProfiler除了提供网页显示报告,还支持将报告结果存储在数据库中,后面我会补充一篇文章来说明如何将报告保存到数据库中。

本篇源代码: https://github.com/lamondlu/Sample_MiniProfiler

转载于:https://www.cnblogs.com/sylone/p/11024386.html

ASP.NET Core WebAPI中的分析工具MiniProfiler相关推荐

  1. NET问答: 如何将 ASP.NET Core WebAPI 中抛出的异常封装成对象?

    咨询区 rianjs: 在 ASP.NET Core WebAPI 中,我的 Controller 代码如下: [Route("create-license/{licenseKey}&quo ...

  2. 在 Asp.Net Core WebAPI 中防御跨站请求伪造攻击

    什么是跨站请求伪造 跨站请求伪造(英语:Cross-site request forgery),也被称为 one-click attack 或者 session riding,通常缩写为 CSRF 或 ...

  3. ASP.NET Core WebAPI中使用JWT Bearer认证和授权

    为什么是 JWT Bearer ASP.NET Core 在 Microsoft.AspNetCore.Authentication 下实现了一系列认证, 包含 Cookie, JwtBearer,  ...

  4. ASP.NET CORE WebAPI 中 Route 属性配置

    1 访问路径属性  Route public class OrdersController : ApiController {[Route("customers/{customerId}/o ...

  5. ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必是件很痛苦的事情吧,但文档又必须写,而且文档的格式如果没有具体要求的话,最终完成的文档则完全取决于开发者 ...

  6. 【转】ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    原文链接:https://www.cnblogs.com/yilezhu/p/9241261.html 引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必 ...

  7. .NET Core WebApi中实现多态数据绑定

    什么是多态数据绑定? 我们都知道在ASP.NET Core WebApi中数据绑定机制(Data Binding)负责绑定请求参数, 通常情况下大部分的数据绑定都能在默认的数据绑定器(Binder)中 ...

  8. Asp.Net Core WebAPI+PostgreSQL部署在Docker中

    PostgreSQL是一个功能强大的开源数据库系统.它支持了大多数的SQL:2008标准的数据类型,包括整型.数值值.布尔型.字节型.字符型.日期型.时间间隔型和时间型,它也支持存储二进制的大对像,包 ...

  9. NET Core的代码安全分析工具 - Security Code Scan

    NET Core的代码安全分析工具 - Security Code Scan 原文:NET Core的代码安全分析工具 - Security Code Scan NET Core的代码安全分析工具 - ...

最新文章

  1. Gradle系列教程之依赖管理
  2. @import注解_Spring 注解之@Import 注入的各种花活
  3. HTML/CSS[收藏]
  4. scp 安全复制(远程文件复制工具)
  5. VC++学习(6):菜单编程
  6. 如何优化WebRTC提升直播体验?
  7. 图结构练习——最小生成树
  8. Linux笔记-iptables规则原理和组成
  9. ubuntu 下安装和启动SSH 服务
  10. Ubuntu 14.04安装Python3
  11. 用简单英语谈生意-介绍篇
  12. Spring AOP术语:连接点和切点的区别。
  13. ffmpeg水平翻转视频,附批量处理脚本
  14. Android Provision(开机向导setupwizard程序)
  15. 关于Unity LitJson写入数据报错的问题
  16. Centos使用yum报错---网络问题
  17. 【20】ubuntu下没有dos2unix命令怎么办
  18. mysql二进制日志
  19. R语言将向量数据按照行方式转化为矩阵数据(设置参数byrow为TRUE)
  20. Lum proxy代理IP如何在AdsPower浏览器上使用

热门文章

  1. win安装wordcloud报错解决方案
  2. Bootstrap UI 编辑器
  3. 【学习笔记】树形结构基础
  4. pku 1691 Painting A Board DFS 抽象建图 + 拓扑排序
  5. 【原】display:inline-block下的IE元素
  6. 基于NHibernate的三层结构应用程序开发初步
  7. 重载函数与函数模板(转)
  8. C++实现平衡二叉树
  9. Spring.Net学习
  10. css3属性box-sizing:border-box 用法解析