我有这个旧软件,它只允许您一次运行一个副本,它会检测到您打开了另一个会话,并且不允许您打开第二个实例。问题是这是一个 cpu 密集型程序,它只使用一个内核。是否有任何黑客或调整,以便我可以欺骗它并打开多个实例?这将使我能够淘汰大约 5 台服务器……我使用的是 Windows 2008 R2。
我不得不使用 cff explorer 来启用超过 2GB 的 RAM,因为程序在尝试使用超过 2GB 时崩溃。
我有这个旧软件,它只允许您一次运行一个副本,它会检测到您打开了另一个会话,并且不允许您打开第二个实例。问题是这是一个 cpu 密集型程序,它只使用一个内核。是否有任何黑客或调整,以便我可以欺骗它并打开多个实例?这将使我能够淘汰大约 5 台服务器……我使用的是 Windows 2008 R2。
我不得不使用 cff explorer 来启用超过 2GB 的 RAM,因为程序在尝试使用超过 2GB 时崩溃。
将程序限制为只有一个实例不是操作系统功能:它必须在代码中进行编码。
这意味着正确答案是:这取决于程序如何执行单实例检测。有几种方法可以做到这一点:
使用互斥量。这是最简单的方法,也是最常用的方法。在其最简单的化身中,互斥锁将被限制在当前用户上下文中,这意味着您可以通过创建不同的服务实例来运行程序并在不同用户的上下文中运行每个服务实例来欺骗程序运行多次。当然,这假设您可以完全自动化该程序。通常也可以编写一个“包装器”应用程序来操纵互斥锁,并以允许其他实例运行的方式更改它。
检查进程列表中的 exe 名称。琐碎:重命名 exe,运行。
锁定特定文件。这可能很简单,也可能很困难,具体取决于文件的位置。
锁定本地资源(TCP 端口等)。这通常是最难解决的,因为没有简单的方法来欺骗应用程序不使用该资源(特别是如果它真的被使用,而不仅仅是锁定以防止并发)。
在所有情况下,最简单的做法就是要求开发人员取消该限制。
Sandboxie在设计时并没有考虑到这一用途,但由于它在虚拟“瓶子”中运行进程的方式,它可用于运行通常只允许运行一个实例的应用程序的多个实例。
另一种可能的选择:只允许单个实例的程序通常通过创建互斥锁来实现。启动新实例时,会检查互斥量是否存在,如果找到则停止执行。可以编写一个可以启动实例然后删除其互斥量的程序。请注意,不希望有多个并发实例的应用程序使用这种方法很可能会出现问题,因此某种程度的虚拟化是更可取的,这样每个实例就不会知道或与其他实例交互。
App-V可能会在这里帮助你。它允许您运行同一虚拟化程序的多个实例,每个实例彼此隔离。
Ctrl + Shift + 双击应用程序快捷方式图标
它将打开应用程序的新实例