nps 无法在计划任务启动npc

vyswwuz2  于 2022-11-05  发布在  其他
关注(0)|答案(4)|浏览(282)

Describe the bug

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

jyztefdp

jyztefdp1#

自己写错了吧,我这一切正常。

6yt4nkrj

6yt4nkrj2#

已经升级到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不同。

mec1mxoz

mec1mxoz3#

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>
6ioyuze2

6ioyuze24#

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,也不会允许打开窗口,程序就直接崩溃。
由于程序不写日志也不留日志文件,具体怎样就只能让开发者自己看了。

相关问题