草庐IT

Feign的性能优化

全部标签

c# - EF 4.0 中看似无限的堆栈跟踪和负载下的查询性能不佳

在大型EF4.0模型(700多个实体)上,我们在System.Data.Objects.ObjectContext.CreateObjectSet(string)上的性能很差。对此的调用由类似context.Users.FirstOrDefault(u=>u.userId=100)的查询触发。查询总体上表现良好,但在负载下查询表现不佳。我们正在对使用此查询的页面运行20个并发用户负载。此页面的应用程序处于分析模式下,即我们在运行此小型负载测试时使用VisualStudio2010性能分析器。探查器正在使用“采样”模式。该应用程序是使用ASP.NET4.0/ASP.NETMVC3.0构建

c# - 如何使用 Windows 性能分析器查看 EventSource 创建的 ETW 事件?

我想使用EventSource触发ETW事件并使用WindowsPerformanceAnalyzer查看它们。我有一个基本的EventSource:[EventSource(Name="BasicEventSource")]publicclassETWLogger:EventSource{#ifDEBUGprivateconstboolThrowOnError=true;#elseprivateconstboolThrowOnError=false;#endifprivateETWLogger(boolthrowOnError):base(throwOnError){}private

c# - 这是.Net Native 编译和优化中可能存在的错误吗?

我在.NetNative和structs中发现了(可能是)过度优化的问题。我不确定是编译器太激进了,还是我太盲目了,看不出我做错了什么。要重现这一点,请按照下列步骤操作:第1步:在VisualStudio2015Update2中创建一个新的空白通用(win10)应用,目标版本为10586,最小版本为10240。调用项目NativeBug所以我们有相同的命名空间。第2步:打开MainPage.xaml并插入此标签第3步:将以下内容复制/粘贴到MainPage.xaml.csusingSystem;usingSystem.Collections.Generic;namespaceNativ

c# - 当前进程的性能计数器 CPU 使用率超过 100

我想显示我的多线程应用程序(在多核处理器上工作)的CPU使用情况。我想收到接近任务管理器的号码。但我得到的数字超过100%。甚至超过500%。是的,我知道,对于类别"Process"的计数器"%ProcessorTime"我需要划分为Environment.ProcessorCount或“NumberOfLogicalProcessors”(与我的配置相同)。而500%是此操作之后的结果。我在具有不同硬件(i7、i5、Core2)和软件配置(具有所有更新的Windows7SP1、具有所有更新的Windows2008R2SP1)的不同计算机上测试了这个示例,但遇到了同样的问题。publi

c# - NHibernate vs Entity Framework 6 对大量用户的性能

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion我正在构建应该经常与数据库通信的大型Web应用程序。我想知道应该使用哪个库来通信NHibernate或EntityFramework6?这是我的应用规范:用户:为大量用户构建的应用程序,让我们从100,000名注册用户开始。50,000用户在线,每个用户每秒最多发送1条消息。每秒发送15,000条消息。内存:保持内存处于正常状态非常重要,所以我想我应该使用LazyLoad?数据库:数据库结

c# - IEnumerable<T>.Count 在哪些情况下进行了优化?

使用reflector我注意到System.Linq.Enumerable.Count方法中有一个条件可以针对IEnumerable的情况对其进行优化。passed实际上是一个ICollection.如果转换成功,Count方法不需要遍历每个元素,而是可以调用ICollection的Count方法。基于此,我开始认为IEnumerable可以像集合的只读View一样使用,而不会出现我最初基于IEnumerable的API预期的性能损失我感兴趣的是是否优化了CountIEnumerable时仍然成立是Select的结果关于ICollection的声明,但根据反射(reflect)的代码,

浅谈与性能相关的设计模式

博客主页:https://tomcat.blog.csdn.net博主昵称:农民工老王主要领域:Java、Linux、K8S期待大家的关注💖点赞👍收藏⭐留言💬目录代理模式CGLibJDKSpring动态代理单例模式饿汉模式饱汉模式享元模式案例:Integer多视角看问题原型模式小结代码的结构对应用的整体性能,有着重要的影响。结构优秀的代码,可以避免很多潜在的性能问题,在代码的扩展性上也有巨大的作用;结构清晰、层次分明的代码,也有助于帮你找到系统的瓶颈点,进行专项优化。设计模式就是对常用开发技巧进行的总结,它使得程序员之间交流问题,有了更专业、便捷的方式。比如,我们在Java性能优化的七个方向这

c# - 为什么重用 DataContext 会对性能产生负面影响?

经过fairamountofresearch还有一些errors,我修改了我的代码,以便在每次查询数据库或插入数据时创建一个新的DataContext。并且频繁查询数据库-对于处理的25万笔交易中的每笔交易,在插入交易之前查询数据库以获得客户ID、部门ID和类别。所以现在我正在尝试优化代码,因为它每秒只处理大约15笔交易。我删除了一些无关的查询并添加了一些索引并将其提高到每秒30个。然后我想即使每个人都说DataContext是轻量级的,但每次事务创建一个新的4次还是要花一些钱,所以我尝试重用DataContext。令我惊讶的是,重用上下文会导致性能下降到每秒10个事务!为什么会这样?

c# - 为属性 setter 或 getter 创建一个高性能的开放委托(delegate)

开放委托(delegate)是对没有目标的实例方法的委托(delegate)。要调用它,您需要提供目标作为它的第一个参数。它们是优化代码的聪明方法,否则会使用反射并导致性能不佳。有关开放委托(delegate)的介绍,请参阅this.您在实践中使用它的方式是使用昂贵的反射代码来构建这些开放的委托(delegate),但是您可以像简单的委托(delegate)调用一样非常便宜地调用它们。我正在尝试编写代码,将任意PropertyInfo转换为其setter的此类委托(delegate)。到目前为止,我想出了这个:usingSystem;usingSystem.Collections.Ge

c# - C# 是否在循环/lambda 语句中自动优化代码?

例如,在Javascript中,强烈建议将函数调用放在循环之外以获得更好的性能:varid=someIdType.ToString();someList.Where(a=>a.id==id)...C#怎么样?相同情况还是编译器/运行时使用内部优化/缓存?someList.Where(a=>a.id==someIdType.ToString())...可能是菜鸟问题,之前有人问过,但找不到引用。 最佳答案 C#代码:Listlist=newList();list.Where(a=>a==typeof(String).ToString(