gpt4 book ai didi

.net - StructureMap 在 Session 中注入(inject)时警告警告 - 为什么?

转载 作者:行者123 更新时间:2023-12-04 22:32:21 24 4
gpt4 key购买 nike

StructureMap documentation on life cycle他们声明一个范围选项是 HttpSession 并且它:“缓存 HttpContext.Session 集合中的实例。谨慎使用。”

我不知道要小心什么,我的 google-fu 让我失望了。

我们的用例是我们想要缓存一些昂贵的 Web 服务调用。其中一些是无状态的,但其中一些与特定用户相关联。

如果我们在 Session 范围内注入(inject),我们什么时候是坏的、顽皮的人?我们需要防范什么?

最佳答案

我将通过一个极端的例子来描述这个问题,缓存一个工作单元对象(例如 LINQ to SQL 的 DataContext , Entity Framework 的 ObjectContextDbContext 或 NHibernate 的 ISession ):

内存占用

工作单元对象通常包含大量对象。将 session 对象放入 HttpSession 意味着只要 session 存在,它就会存在,并且缓存中的所有对象都将存在。即使用户在 20 分钟后回来,您的应用程序也会有这种内存压力。这可能(并且在相当大的负载下)会导致内存不足异常。

数据变得陈旧

由于工作单元对象缓存了它从数据库加载的所有实体,因此该数据很快就会变得陈旧。当数据被其他用户更改时,默认情况下不会刷新缓存的数据,并且您可能会遇到奇怪的行为,即一个用户看到一些数据,但另一个用户看到其他数据。刷新页面将不起作用,因为您在 session 的生命周期内缓存了数据。只有关闭浏览器才会起作用(有时)。

序列化

当您扩展您的 Web 服务器(这意味着您添加更多服务器)时, session 信息必须从一台服务器传输到另一台服务器。您将不得不使用进程外缓存(例如 MemCache 或 SQL Server)。工作单元对象很难或不可能序列化和反序列化,这意味着您无法根据需要或需要进行横向扩展。

总结

这个例子是极端的,因为你不应该在工作单元模式上使用每个 session 的生活方式。但它仍然相当清楚地描述了这个问题。每个 session 的生活方式增加了应用程序的内存占用,因为服务保持事件很长时间。如果您使用此类服务​​来缓存数据,它可能会变得陈旧(尽管缓存可能只是您提高性能所需要的)。尽管 DTO 通常很容易序列化,但这不适用于您注册的任何服务。这意味着您无法横向扩展,因为需要可序列化的 session 对象才能横向扩展。

因此,不要在服务上使用 Per Session 生活方式,而是尝试构建无状态的服务,以便它们可以注册为单例。可以从 HTTP session 请求他们需要的任何用户特定数据。

关于.net - StructureMap 在 Session 中注入(inject)时警告警告 - 为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17702546/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com