- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含大约 30 个项目的解决方案,其中大部分使用 Microsoft Unity 作为容器。
对于此测试,我在不同区域和不同网络中使用远程 Azure SQL 数据库,因此我预计响应会延迟,但这不会影响此测试。
让我们计算使用 Unity 的数据访问时间和使用 DbContext 的直接数据访问时间,这是以毫秒为单位的平均计算:
Unity Container
8749
5757
7225
7072
7256
8791
7016
7465
8449
10741
7852.1 (average)
DbContext
3599
2239
2902
2378
1898
1682
1692
1522
2773
2054
2273.9 (average)
因此,使用 unity 容器访问数据需要 7852.1(平均)毫秒,同时使用 DbContext 访问数据需要 2273.9(平均)毫秒。这是一个很大的性能瓶颈,你不觉得吗?
让我分享一些代码片段,这将展示我如何在项目中使用 Unity。
项目中的 Unity 配置如下所示:
public class UnityConfig
{
private static Lazy<IUnityContainer> container = new Lazy<IUnityContainer>(() =>
{
var container = new UnityContainer();
RegisterTypes(container);
return container;
});
public static IUnityContainer GetConfiguredContainer()
{
return container.Value;
}
public static void RegisterTypes(IUnityContainer container)
{
//// Repositories
container.RegisterType<ICartRepository, CartRepository>();
// .... total 50 repositories registrations ....
//// Services
container.RegisterType<ICartService, CartService>();
// .... total 72 services registrations ....
}
}
public static class UnityWebActivator
{
public static void Start()
{
var container = UnityConfig.GetConfiguredContainer();
FilterProviders.Providers.Remove(FilterProviders.Providers.OfType<FilterAttributeFilterProvider>().First());
FilterProviders.Providers.Add(new UnityFilterAttributeFilterProvider(container));
DependencyResolver.SetResolver(new UnityDependencyResolver(container));
// TODO: Uncomment if you want to use PerRequestLifetimeManager
// Microsoft.Web.Infrastructure.DynamicModuleHelper.DynamicModuleUtility.RegisterModule(typeof(UnityPerRequestHttpModule));
}
public static void Shutdown()
{
var container = UnityConfig.GetConfiguredContainer();
container.Dispose();
}
}
这是与 Unity 一起使用的示例存储库和示例服务:
public interface ICartRepository
{
Cart Get(string id);
IEnumerable<Cart> GetAll();
// more codes
}
public class CartRepository : ICartRepository
{
[Dependency]
public ApplicationData db { get; set; }
public Cart Get(string id)
{
return db.Carts.AsNoTracking().Where(i => i.Id == id && i.IsDeleted == 0).FirstOrDefault();
}
public IEnumerable<Cart> GetAll()
{
return db.Carts.AsNoTracking().Where(i => i.IsDeleted == 0);
}
// more codes
}
public interface ICartService
{
Cart Get(string id, string orgid);
IEnumerable<Cart> GetAll(string orgid);
// more codes
}
public class CartService : ICartService
{
private ICartRepository cartRepository;
public CartService(ICartRepository _cartRepository)
{
cartRepository = _cartRepository;
}
public Cart Get(string id, string orgid)
{
return cartRepository.GetAll().Where(i => i.OrganizationId == orgid && i.Id == id).FirstOrDefault();
}
public IEnumerable<Cart> GetAll(string orgid)
{
return cartRepository.GetAll().Where(i => i.OrganizationId == orgid);
}
// more codes
}
在我使用它们的项目中:
public class HomeController : Controller
{
private ICartService cartService;
public HomeController(ICartService _cartService)
{
cartService = _cartService;
}
public ActionResult Index()
{
// through unity
var item = cartService.Get("id", "org_id");
// direct DbContext
ApplicationData data = new ApplicationData();
var item1 = data.Carts.AsNoTracking().Where(i => i.Id == "id" && i.OrganizationId == "org_id").FirstOrDefault();
// more code
return View();
}
}
这就是我们在应用程序中使用的所有内容。您是否看到可以更改以提高性能的任何内容?
最佳答案
原因是您比较的两种方式完全不同,而不是因为 Unity。第一种方法:
var item = cartService.Get("id", "org_id");
实现为
return cartRepository.GetAll().Where(i => i.OrganizationId == orgid && i.Id == id).FirstOrDefault()
在哪里GetAll
是:
public IEnumerable<Cart> GetAll()
{
return db.Carts.AsNoTracking().Where(i => i.IsDeleted == 0);
}
因为 GetAll
返回类型是 IEnumerable<Cart>
- cartRepository.GetAll().Where(...)
将不会过滤掉数据库中的购物车。相反,整个 Cart
使用类似 select * from Cart where IsDeleted = 0
的 SQL 查询将表拉入内存.那么Where
被执行并找到目标购物车(按组织和 ID)在内存中。当然这是非常低效的(因为它将整个表从您的远程数据库传输到您的机器)并且比另一个 appoach 花费更多的时间,它做:
data.Carts.AsNoTracking().Where(i => i.Id == "id" && i.OrganizationId == "org_id").FirstOrDefault();
这个生成你期望的 SQL,比如 select top 1 * from Cart where IsDeleted = 0 and Id = @id and OrganizationId = @org_id
,所有过滤都发生在数据库中,然后通过网络仅传输一行。
要修复 - 更改您的 GetAll
(和其他类似方法)返回 IQueryable
:
public IQueryable<Cart> GetAll()
{
return db.Carts.AsNoTracking().Where(i => i.IsDeleted == 0);
}
关于c# - Unity 容器性能优于直接数据访问 - 一个很大的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49271181/
我想显示一个图像(大于 iPhone 的屏幕),用户可以滚动。不难,我已经用这段代码完成了:在我的 .h 文件中 @interface mappa1 : UIViewController { IBO
bash 联机帮助页说: Redirecting Standard Output and Standard Error Bash allows both the standard output (fi
我将大量数据绑定(bind)到 TreeView 控件,因为数据是自然的类别层次结构。问题是它有很多。我已经设法通过仅绑定(bind)那些出现在可见树中的节点来消除大量开销,但这仍然在 ViewSta
我正在尝试为 mysql 操作与 redis 操作制作基准测试脚本。 这是我尝试过的: 1./ List of comment ids with a separate hash of comment
我很想知道是否有比 FileObserver 更好的方法来监视目录的文件更改/创建/删除。 FileObserver 需要持续引用它,这需要持续运行的服务,这很困难,也是一种不好的做法,对吧? 对于如
我创建了一个带有 NSOpenGLView 的窗口,我正在将 openGL 内容渲染到其中。 我想向 View 添加一些按钮和文本字段:我可以使用界面生成器(或代码)添加 NSTextFields 和
如何编码 JAXBElement 列表? 例如,我有一个无法注释的 POJO: public class APojo { private String aString; public APojo()
我正在开发一个博客,我的客户希望在其中使用大量图像(文章、标题、广告等)。他几乎不想要任何文本,因为他希望用阿拉伯语开发博客并且他对网络浏览器支持的任何字体都不满意,他也不想采用 EOT,他将每天更新
我想在文本字段上添加一个标签,该标签会在用户键入时发生变化。问题是文本字段的插入符号位于标签后面(如果我将标签放在文本字段前面)。我始终可以使文本字段的背景透明,并在标签和文本字段后面添加另一个禁用的
我正在尝试在 iOS 应用程序中创建一个特定的布局,其中“背景”是一个 MKMapView,覆盖层是一个 UIScrollView。这个想法是有两个屏幕,一个带有 map ,另一个带有一些附加信息。用
我需要在 UITableViewController 上放置一个 UIView,目前我是这样放置的 [self.navigationController.view addSubview:searchV
我有一个非常简单的问题要问:我需要在屏幕右下角的 ImageView 上放一个小 Logo ,整个屏幕都很大,但我不知道如何设置坐标或如何设置说 ImageViews 处于相对位置。 像这样: 最佳答
我试图让 mapView 覆盖整个 UITableViewCell 并禁用此 mapView 上的所有用户事件,但仍然可以单击单元格。但是,此 mapView(即使我将 subview 发送回)正在拦
我们即将获得 Java EE6(使用 Glassfish v3 作为引用实现)。计划发布时间为 12 月 9 日。虽然仍有相当多的公司正在努力将他们的代码库从早期版本迁移到 EE5,但我们处于开始开发
为什么(在 WPF、C#、 Entity Framework 中)将 ListBox 绑定(bind)到在 ObjectSet 上创建的 ObservableCollection(来自 Entity框
在 hibernate 中使用 @NamedQuery 而不是 @NamedNativeQuery 有什么好处,反之亦然。我无法发现确切的区别或在什么情况下我们应该使用 @NamedQuery 而不是
在 Dart 中,检查值是否为 == null似乎类似于检查它是否is Null .为什么前者更可取? 最佳答案 这是您正在进行的比较类型。在 == null ,您正在将对象/原始对象与 null 进
我使用的是 Java 1.6。我有一组项目,每个项目都有一个名称和一组组件。每个组件也有一个名称。 Set Class Item String name Set Class Compo
如果我想在我的应用程序中支持脚本,是否 scriptcs提供比仅使用普通 Vanilla 的任何特殊优势 Roslyn脚本引擎? 最佳答案 不幸的是,目前还没有太多关于托管 scriptcs 的文档,
我正在我的应用程序中使用 Struts 和 Spring jdbc 模板。 我必须在我们的代码中使用 Hibernate 模板。 谁能告诉我为什么要使用 Hibernate 模板? 使用 Spring
我是一名优秀的程序员,十分优秀!