使用 MvcMiniProfiler 监控EF 4.1 with MySQL Provider

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 本文有2个不怎么相关的话题,一是用MVCMiniProfiler 监控EF4.1,另一个则是为MvcMiniProfiler提供MySQL Provider的支持。 需要在Web.config中添加system.

本文有2个不怎么相关的话题,一是用MVCMiniProfiler 监控EF4.1,另一个则是为MvcMiniProfiler提供MySQL Provider的支持。

需要在Web.config中添加system.data的节点

   1: <remove invariant="MvcMiniProfiler.Data.ProfiledDbProvider" />
   2: <add name="MvcMiniProfiler.Data.ProfiledDbProvider" invariant="MvcMiniProfiler.Data.ProfiledDbProvider"
   3:         description="MvcMiniProfiler.Data.ProfiledDbProvider"
   4:         type="MvcMiniProfiler.Data.ProfiledDbProviderFactory, MvcMiniProfiler, Version=1.7.0.0, Culture=neutral, PublicKeyToken=b44f9351044011a3" />

另外在Application_Start设置Database.DefaultConnectionFactory即可

   1: var factory = new SqlCeConnectionFactory("System.Data.SqlServerCe.4.0"); 
   2: var profiled = new MvcMiniProfiler.Data.ProfiledDbConnectionFactory(factory);
   3: Database.DefaultConnectionFactory = profiled;

当然,使用MySQL的话需要使用MySQL的ConnectionFactory,但是MySQL没有为我们提供,所以我们就自己写一下

   1: class MySqlConnectionFactory : IDbConnectionFactory
   2:         {
   3:             public DbConnection CreateConnection(string nameOrConnectionString)
   4:             {
   5:                 using (MiniProfiler.Current.Step("创建Connection:" + nameOrConnectionString))
   6:                 {
   7:                     var connStr = ConfigurationManager.ConnectionStrings[nameOrConnectionString];
   8:                     return new MySqlConnection(connStr.ConnectionString);
   9:                 }
  10:             }
  11:         }

然后使用MySqlConnectionFactory来注册

   1: var factory = new MySqlConnectionFactory();
   2: var profiled = new ProfiledDbConnectionFactory(factory);
   3: Database.DefaultConnectionFactory = profiled;

但是有很多时候使用EF4.1这样做并不会生效我们可能还要为DbContext包装一个基类来实现如下功能

   1: abstract public class BaseDbContext :DbContext
   2:    {
   3:        protected BaseDbContext(string nameOrConnectionString)
   4:            : base(GetConnection(nameOrConnectionString),true)
   5:        {
   6:           
   7:        }
   8:  
   9:        private static DbConnection GetConnection(string nameOrConnectionString)
  10:        {
  11:            if( Database.DefaultConnectionFactory is SqlConnectionFactory)
  12:            {//这个判断是为了解决未使用MySqlConnectionFactory时自动使用SQLServer的问题
  13:                var connStr = ConfigurationManager.ConnectionStrings[nameOrConnectionString];
  14:                return new MySqlConnection(connStr.ConnectionString);
  15:            }
  16:            return Database.DefaultConnectionFactory.CreateConnection(nameOrConnectionString);
  17:        }
  18: }
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
20天前
|
存储 监控 关系型数据库
轻松入门Mysql:MySQL性能优化与监控,解锁进销存系统的潜力(23)
轻松入门Mysql:MySQL性能优化与监控,解锁进销存系统的潜力(23)
|
1月前
|
SQL 监控 关系型数据库
MySQL性能调优:监控和优化
MySQL性能调优:监控和优化
54 1
|
2月前
|
监控 关系型数据库 MySQL
HeartBeat监控Mysql状态
HeartBeat监控Mysql状态
|
6月前
|
监控 关系型数据库 MySQL
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
|
2月前
|
监控 关系型数据库 MySQL
MetricBeat监控MySQL
MetricBeat监控MySQL
|
2月前
|
存储 监控 关系型数据库
ELK架构监控MySQL慢日志
ELK架构监控MySQL慢日志
|
2月前
|
SQL 监控 关系型数据库
rds迁移过程监控
rds迁移过程监控
22 1
|
2月前
|
监控 关系型数据库 MySQL
MySQL技能完整学习列表12、性能优化——1、性能指标和监控——2、优化查询和数据库结构——3、硬件和配置优化
MySQL技能完整学习列表12、性能优化——1、性能指标和监控——2、优化查询和数据库结构——3、硬件和配置优化
146 0
|
2月前
|
监控 关系型数据库 MySQL
PHP与MySQL的结合:实现局域网上网行为监控软件的数据库管理
在当今信息化时代,网络安全日益成为重要的话题。为了有效监控和管理局域网上网行为,开发一个基于PHP和MySQL的数据库管理系统是一个理想的选择。本文将介绍如何结合PHP和MySQL,开发一款简单而高效的局域网上网行为监控软件,并重点关注数据库管理方面的实现。
193 0
|
5月前
|
SQL 监控 关系型数据库
给Mysql加语句监控日志
给Mysql加语句监控日志
64 0