首页 技术 正文
技术 2022年11月13日
0 收藏 512 点赞 4,930 浏览 2335 个字

在学习python开发框架pylons/pyramid的过程中,里面有个非常棒的页面性能监控功能,这样在开发过程中,你能清楚的知道当前页面的性能以及其它参数。

这里介绍一下如何给Asp.net MVC和Entity Framework也添加上性能监控,让你在开发过程中随时掌握当前程序运行的信息。

这里是在Autofac+MVC+EF篇的源码基础上,一步一步的介绍添加Profiler的过程。

如果有兴趣了解Autofac的应用,可以看这里 IoC容器Autofac(4) – Autofact + Asp.net MVC + EF Code First(附源码)

最终源代码在这里 MiniProfiler.zip

阅读目录:

一、MiniProfiler应用的结果

二、下载源码,运行程序

三、添加MVC Profiler

四、添加Entity Framework Profiler

五、总结

一,MiniProfiler应用的结果

先看看应用了MiniProfiler的结果

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

二,下载源码,运行程序

1. 下载源代码

源代码的下载地址是 AutofacMVC.zip

2. 使用Nuget下载依赖

源代码使用了Nuget的包管理,可以非常方便的下载外部引用。Nuget的使用,可以看这里Nuget如何自动下载依赖DLL引用

3. 创建数据库

修改web.config中的数据库链接字符串,并创建对应的数据库School, 然后使用EF的Migration创建表结构和初始化数据

在”Package Manager Console”中输入”Update-Database”命令。

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

如果在运行命令的过程中出现了错误:

Package Manager Console Update-Database CommandNotFoundException only in a specific VS project

那么在执行Update-Database命令之前,先运行

Install-Package EntityFramework –IncludePrerelease

4. 最后运行程序,页面如下:

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

三, 添加MVC Profiler

1. 通过Nuget添加MiniProfiler引用

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

2. 在_Layout.cshmlt中添加MiniProfiler

在_Layout.cshtml中添加的MiniProfiler的相关代码,这样就能在每个页面上输出页面的访问信息

由于MiniProfiler生成的js需要依赖于Jquery,所以记得添加对于Jquery的引用。

@using StackExchange.Profiling
<!DOCTYPE html>
<html lang="en">
<head>
<title>Test</title>
<script type="text/javascript" src="~/Scripts/jquery-2.0.3.min.js"></script>
</head>
<body>
@RenderBody()
@MiniProfiler.RenderIncludes()
</body>
</html>

3. 添加MiniProfiler的Handler

上面@MiniProfiler.RenderIncludes()会在页面上生成一段js

类似于

 <script async type="text/javascript" id="mini-profiler" src="/mini-profiler-resources/includes.js?v=xwYPDDH1blvqmxgsBweNC++H7CFU3KGQ+zFcVlJPsXw=" ……
 
我们的系统中,应当添加Handler来处理对于上面的include.js的处理,把它交给MiniProfiler的dll来处理这个js的请求。
<handlers>
<add name="MiniProfiler" path="mini-profiler-resources/*" verb="*" type="System.Web.Routing.UrlRoutingModule" resourceType="Unspecified" preCondition="integratedMode" />
</handers>
 

4. 在Global.asax中启动MiniProfiler记录

如下, 在每个request开始和结束的时候,调用MiniProfiler来记录信息。
protected void Application_BeginRequest()
{
if (Request.IsLocal)
{
MiniProfiler.Start();
}
}protected void Application_EndRequest()
{
MiniProfiler.Stop();
}

5. 完成所有的工作后,重新刷新页面

重新启动,刷新页面,就能看到MiniProfiler记录的结果了。

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

四, 添加Entity Framework Profiler

1, 从Nuget中添加MiniProfiler.EF

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

2. 在Global.asax中,添加代码

protected void Application_Start()
{
MiniProfilerEF.Initialize();
………
}

3. 刷新页面

刷新的页面,能够发现MiniProfiler问我们记录了EF访问数据的信息

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

五,总结

MiniProfiler是平时开发的利器,以可视化的方式让你随时监控开发过程中的性能问题。

MiniProfiler提供了不只是提供了MVC和EF扩展,还有针对windows开发,WCF, NHibernate等.

MiniProfiler应该作为项目开发中的一个标配,如果你的项目中,还没有使用到,赶快试一试,它一定能够为你的开发带来意向不到的正能量。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,487
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,486
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,126
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,287