我创建了一个名为的函数listProcesses
,它按以下顺序调用以下 Vix 命令:
- VixHost_Connect
- VixHost_OpenVM
- VixVM_LoginInGuest
- VixVM_ListProcessesInGuest
- VixVM_LogoutFromGuest
- VixHost_Disconnect
请注意,我没有调用VixVM_PowerOn
,因为我手动启动了虚拟机。
该函数listProcesses()
是用 C 语言编写的,但我将其导出为一个.pyd
文件以与 Python 一起使用。
在 Python 解释器中,我运行以下代码:
from myModule import listProcesses
for i in xrange(1000):
print listProcesses()
该函数listProcesses()
为我提供了循环的前约 30 次迭代的预期输出(代表虚拟机内运行的进程名称的字符串列表)for
,但之后它开始打印一个空列表。
我使用 Visual Studio 2012 中的调试器进行调查,看起来在for
循环约 30 次迭代后,函数VixVM_LoginInGuest()
返回错误3006
。从 Vix 文档中,该错误意味着“需要打开虚拟机电源。”。
我检查过,虚拟机已开机并响应,并且 VmwareTools 仍在虚拟机内运行。
我想补充一点,我按照文档的建议释放了所有手柄。另外,如果有任何帮助,如果我在开始收到错误后暂停执行 python 脚本并重新启动虚拟机,则脚本会开始打印另外约 30 个的预期输出(取决于我运行的主机)脚本,它可能多达 80) 次,然后它再次开始打印一个空列表。
我想知道为什么会出现这个问题。
编辑:在我进一步调查之后,我注意到该函数VixHost_OpenVM
创建了一个到虚拟机的 TCP 连接,并且连接永远不会关闭。当连接数达到一定数量时,操作系统可能会禁止来自我的脚本的任何新连接。有没有办法在不关闭脚本的情况下关闭未使用的连接?