使用Debug Diagnostic Tool分析.net转储

作者:V君 发布于:2016-10-25 11:26 Tuesday 分类:填坑经验

TL;DR:

去M¥官网下载该工具, 对应其x86/x64. 安装时选择关联文件类型. 

装好之后双击要分析的dmp文件. 等一会儿. 一个可视化的mht分析报表就出来了.

注意这工具只能在Vista(NT6)以上环境运行.


转储dmp文件可以用Sysinternals出品的免费系统工具Process Explorer来做.


听我扯扯:

虽然WinDbg+sos/sosex很强大, 但是用起来很复杂, 载入符号也很慢.

于是找到了这货来帮忙, 尽管和前者比起来就差不能在内存中找对象.

但是非常方便收集异常信息以及线程堆栈.

标签: 软件开发 C# 调试技术 windbg

评论(0) 引用(0) 浏览(717)

解决ASP.NET Boilerplate与EntityFramework反复出现无用更新的现象[Update]

作者:V君 发布于:2016-10-23 15:49 Sunday 分类:挖坑经验

TL;DR

重写SaveChanges和SaveChangesAsync ,

在base实现调用之前增加以下代码,去除对前三个字段的无用更新的操作.

private static readonly HashSet<string> IgnoreCheckUpdateFields = new HashSet<string>

{

    nameof(IAudited.CreationTime),

    nameof(IAudited.LastModificationTime),

    nameof(IAudited.LastModifierUserId),

    nameof(Entity.Id),

};


private void BlockNeedLessUpdate()

{

    //LEVEL 1: always CreationTime

    var allModified = ChangeTracker

        .Entries<ICreationAudited>()

        .Where(p => p.State == EntityState.Modified);


    foreach (var item in allModified)

        item.Property(nameof(ICreationAudited.CreationTime))

            .IsModified = false;


    //LEVEL 2: only LastModificationTime LastModifierUserId

    var allModified2 = ChangeTracker

        .Entries<IAudited>()

        .Where(p => p.State == EntityState.Modified);


    foreach (var item in allModified2)

    {

        var changed = item.CurrentValues.PropertyNames

         .Any(p => !IgnoreCheckUpdateFields.Contains(p) 

         && false == item.CurrentValues[p]?.Equals(item.OriginalValues[p]));


        if (changed) continue;

        item.Property(nameof(IAudited.LastModificationTime)).IsModified = false;

        item.Property(nameof(IAudited.LastModifierUserId)).IsModified = false;

    }

}

 

听我扯扯:

由于ASP.NET Boilerplate首次启动/登录时很慢, 于是将EF生成的SQL语句打到调试输出.

发现大量的创建时间被更新的现象. 

深入调查发现可能是因为 CreationAuditedEntity 在构造时初始化成 Clock.Now

然后EF从数据库读出值再次绑定,

造成 CreationTime 的 setter 被多次调用导致变更追踪机制懵逼.

粗暴地把所有对 CreationTime 的更新操作屏蔽就好了.

不知道是不是错觉, 这么做了之后发现调试启动速度快了70%呀.


ps. 或许 EF 的变更追踪没有 dbml 那么完善,它只监视赋值行为.然而 dbml 还检查了值变化.


Update:

随着继续调试又发现Tenant的LastModificationTime和LastModifierUserId被更新

然而并没更新到别的字段, 明显这样的更新动作是无用的.

进一步调试看起来EF只是简单的比较了两个装了箱的值, 然而在SQL层面又做了值重复过滤

导致这种尴尬现象.

标签: 软件开发 C# 数据库

评论(0) 引用(0) 浏览(846)

解决ASP.NET Boilerplate连接MS SQL报Filter name MustHaveTenant not found

作者:V君 发布于:2016-10-23 15:20 Sunday 分类:挖坑经验

TL;DR

重写 OnModelCreating 要调用base实现. 加上调用base实现需要重建数据库.

 

 

听我扯扯:

受够MySQL提供程序的bug之后, 换MS SQL看看会不会好点.

直接在 DbContext 和迁移剔除所有 MySQL 的 Attribute

再去Web.Config把所有My配置去掉.连接字符串改到MS SQL.

 

编译然后生成数据库报错了. 提示 ON DELETE NO ACTION

咕狗到爆栈帖子说是实体关系配置问题. 重写了 OnModelCreating 方法.

 

然后, 尽管数据库生成出来了.

然而运行起来就爆炸鸟:Filter name MustHaveTenant not found....

 

各种问, 各种咕狗. 然后找到了ABP作者的回帖最终完美解决问题, 顺利地跑起来!

接下来看看EF-LINQ提供程序做复杂投影有没有MySQL的问题吧!

标签: 软件开发 C# 数据库 运行时错误

评论(0) 引用(0) 浏览(1503)

Powered by emlog 去你妹的备案 sitemap