nps
nps copied to clipboard
无法在计划任务启动npc
Describe the bug Win10 Pro npc可以直接运行,也可以在编写的一个bat中执行(包含了npc带参数)。 但将此程序加入计划任务后,npc会在启动后立即退出,且不返回任何错误信息,也不输出任何错误内容(重定向到文件会产生空文件)。
自己写错了吧,我这一切正常。

已经升级到Win11。问题依旧。详细信息: 1 使用bat(cmd)而不是ps。 2 参数是-server=myserver:port -vkey=mykey -type=tcp 3 bat的全文是
:start
npc -server=myserver:port -vkey=mykey -type=tcp
goto start
4 此bat直接丢在启动组里则没有问题。 5 不使用bat,而直接将npc作为计划任务执行,问题依旧,只不过行为略有不同——执行后直接退出,返回0x0。 6 使用ps调用npc依旧会退出。ps的脚本如下:
while(1)
{
.\npc.exe -server=myserver:port -vkey=mykey -type=tcp
}
使用ps的计划任务文件如下:
<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
<RegistrationInfo>
<Date>2022-03-29T10:04:10.9304152</Date>
<Author>HOMEPC\Allen</Author>
<URI>\Remote\npc</URI>
</RegistrationInfo>
<Triggers>
<BootTrigger>
<Enabled>true</Enabled>
</BootTrigger>
</Triggers>
<Principals>
<Principal id="Author">
<UserId>S-1-5-21-1345928514-2849764542-326515779-1001</UserId>
<LogonType>Password</LogonType>
<RunLevel>LeastPrivilege</RunLevel>
</Principal>
</Principals>
<Settings>
<MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
<DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
<StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
<AllowHardTerminate>true</AllowHardTerminate>
<StartWhenAvailable>true</StartWhenAvailable>
<RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
<IdleSettings>
<StopOnIdleEnd>true</StopOnIdleEnd>
<RestartOnIdle>false</RestartOnIdle>
</IdleSettings>
<AllowStartOnDemand>true</AllowStartOnDemand>
<Enabled>true</Enabled>
<Hidden>false</Hidden>
<RunOnlyIfIdle>false</RunOnlyIfIdle>
<WakeToRun>false</WakeToRun>
<ExecutionTimeLimit>PT0S</ExecutionTimeLimit>
<Priority>7</Priority>
</Settings>
<Actions Context="Author">
<Exec>
<Command>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe</Command>
<Arguments>.\run.ps1</Arguments>
<WorkingDirectory>c:\Program Files\npc</WorkingDirectory>
</Exec>
</Actions>
</Task>
7 直接执行ps1脚本可以正常执行。 8 退出指:npc启动后自动退出,在任务管理器可以看到npc自动重启(由于脚本设置了循环),每次启动的pid不同。
6 ps脚本我是这样的
./npc.exe -server [ip:port] -vkey [vkey] -type tcp
如果是windows 参数名和值之间是 空格 而不是=, 这点似乎文档不对。
另外任务里面的 WorkingDirectory 不确定 \ 行不行。
<Exec>
<Command>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe</Command>
<Arguments>./start.ps1</Arguments>
<WorkingDirectory>d:\\tools\\npc</WorkingDirectory>
</Exec>
6 ps脚本我是这样的
./npc.exe -server [ip:port] -vkey [vkey] -type tcp如果是windows 参数名和值之间是 空格 而不是=, 这点似乎文档不对。
另外任务里面的
WorkingDirectory不确定\行不行。<Exec> <Command>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe</Command> <Arguments>./start.ps1</Arguments> <WorkingDirectory>d:\\tools\\npc</WorkingDirectory> </Exec>
已照此设置,问题依旧。
发现可能是程序需要使用Console对象或者User Profile的bug。
直接启动时,或者计划任务设置为Run only when user is logged on时,窗口会自动打开,所以Console对象是可以获得的。 但计划任务设置成Run whether user is logged on or not,这时候没有Profile,也不会允许打开窗口,程序就直接崩溃。 由于程序不写日志也不留日志文件,具体怎样就只能让开发者自己看了。