[英]Multiple processes and copies of static DLL data in COM DLL dependencies
我希望了解COM DLL运行中的某些意外行为,其中似乎在多个进程之间共享了静态C ++数据。 环境有点复杂,我对各种COM线程模型的理解还很薄弱,我希望有人可以提供帮助。
环境
观察到的问题是,Utilities.dll中的静态数据似乎最终在不同的IIS进程之间共享,从而产生了不良后果。 我曾预料到,由于COM位于主STA中,因此它们将被访问,就好像它不是线程安全的一样,每个进程将获得自己的DLL静态数据副本,但是事实并非如此。
有人可以解释静态数据最终如何在进程之间共享吗?
如何避免这种情况? (除了重构代码以删除所有静态数据外,当前尚不可行)
如果看到COM对象之间共享的数据,则意味着它们托管在同一进程中。 是的,可以在进程之间共享数据,但并非偶然。 由于您的应用程序池是不同的进程,因此必须将这些COM对象托管在进程外,并且只是将存根加载到应用程序池中。
如果您可以控制Utilities.dll(听起来像您一样),那么我将尝试添加一些调试信息,以查找承载COM对象的进程ID。 我希望您会发现它与应用程序池ID不匹配,并且您将能够使用该ID找出正在发生的事情。
理想情况下,设计良好的COM对象位于何处都应该无关紧要,这应该是实现细节。 是否可以取消共享数据结构?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.