lba*_*anz 5 windows windows-server-2008-r2
我有这个遗留软件,它一次只允许您运行一个副本,它检测到您打开了另一个会话,并且不允许您打开第二个实例。问题是这是一个 CPU 密集型程序,它只使用一个内核。是否有任何黑客或调整,以便我可以欺骗它并打开多个实例?这将允许我退休大约 5 台服务器...我使用的是 Windows 2008 R2。
我不得不使用 cff explorer 来启用超过 2GB 的 RAM,因为程序在尝试使用超过 2GB 时会崩溃。
将程序限制为一个实例并不是操作系统功能:它必须在代码内部进行编码。
这意味着正确答案是:这取决于程序如何执行单实例检测。有几种方法可以做到这一点:
使用互斥锁。这是最简单的方法,也是最常用的。在其最简单的化身中,互斥锁将仅限于当前用户上下文,这意味着您可以通过创建不同的服务实例来运行程序并在不同用户的上下文中运行每个服务实例来欺骗程序多次运行。当然,这假设您可以完全自动化程序。通常也可以编写一个“包装器”应用程序来操作互斥锁,并以允许其他实例运行的方式更改它。
检查进程列表中的 exe 名称。微不足道:重命名exe,运行。
锁定特定文件。根据文件的位置,这可能是微不足道的或困难的。
锁定本地资源(TCP 端口等)。这通常是最难解决的,因为没有简单的方法可以诱使应用程序不使用该资源(特别是如果它真的被使用,而不仅仅是为了防止并发而锁定)。
在所有情况下,最简单的做法是要求开发人员解除该限制。
归档时间: |
|
查看次数: |
24559 次 |
最近记录: |