我希望了解COM DLL运行中的一些意外行为,其中出现静态C ++数据正在多个进程之间共享。环境有点复杂,我对各种COM线程模型的理解相当薄弱,我希望有人可以帮忙。
环境
观察到的问题是,Utilities.dll中的静态数据似乎最终会在不同的IIS进程之间共享,从而产生不良后果。我曾预料到,由于COM在主STA中,它们将被访问,好像它不是线程安全的,每个进程都会获得自己的DLL静态数据副本,但似乎并非如此。
有人可以解释静态数据最终如何在进程之间共享?
我该如何避免这种情况? (除了重构代码以删除当前不可行的所有静态数据)
答案 0 :(得分:1)
如果您看到COM对象之间共享数据,则意味着它们托管在同一进程中。是的,可以在进程之间共享数据,但不是偶然的。由于您的应用程序池是不同的进程,因此必须将这些COM对象托管在进程外,并且它只是加载到应用程序池中的存根。
如果您可以控制Utilities.dll(听起来就像这样),我会尝试添加一些调试信息,以找出托管COM对象的进程ID。我希望您会发现它与应用程序池ID不匹配,并且您将能够使用该ID来查明正在发生的事情。
理想情况下,精心设计的COM对象存在于哪里应该无关紧要,这应该是一个实现细节。是否有可能取消共享数据结构?