Describe the bug
Win10 Pronpc可以直接运行,也可以在编写的一个bat中执行(包含了npc带参数)。但将此程序加入计划任务后,npc会在启动后立即退出,且不返回任何错误信息,也不输出任何错误内容(重定向到文件会产生空文件)。
jyztefdp1#
自己写错了吧,我这一切正常。
6yt4nkrj2#
已经升级到Win11。问题依旧。详细信息:1 使用bat(cmd)而不是ps。2 参数是-server=myserver:port -vkey=mykey -type=tcp3 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不同。
mec1mxoz3#
6 ps脚本我是这样的
./npc.exe -server [ip:port] -vkey [vkey] -type tcp
如果是windows 参数名和值之间是 空格 而不是=, 这点似乎文档不对。
另外任务里面的 WorkingDirectory 不确定 \ 行不行。
WorkingDirectory
\
<Exec> <Command>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe</Command> <Arguments>./start.ps1</Arguments> <WorkingDirectory>d:\\tools\\npc</WorkingDirectory> </Exec>
6ioyuze24#
已照此设置,问题依旧。
发现可能是程序需要使用Console对象或者User Profile的bug。
直接启动时,或者计划任务设置为Run only when user is logged on时,窗口会自动打开,所以Console对象是可以获得的。但计划任务设置成Run whether user is logged on or not,这时候没有Profile,也不会允许打开窗口,程序就直接崩溃。由于程序不写日志也不留日志文件,具体怎样就只能让开发者自己看了。
4条答案
按热度按时间jyztefdp1#
自己写错了吧,我这一切正常。
6yt4nkrj2#
已经升级到Win11。问题依旧。详细信息:
1 使用bat(cmd)而不是ps。
2 参数是-server=myserver:port -vkey=mykey -type=tcp
3 bat的全文是
4 此bat直接丢在启动组里则没有问题。
5 不使用bat,而直接将npc作为计划任务执行,问题依旧,只不过行为略有不同——执行后直接退出,返回0x0。
6 使用ps调用npc依旧会退出。ps的脚本如下:
使用ps的计划任务文件如下:
7 直接执行ps1脚本可以正常执行。
8 退出指:npc启动后自动退出,在任务管理器可以看到npc自动重启(由于脚本设置了循环),每次启动的pid不同。
mec1mxoz3#
6 ps脚本我是这样的
如果是windows 参数名和值之间是 空格 而不是=, 这点似乎文档不对。
另外任务里面的
WorkingDirectory
不确定\
行不行。6ioyuze24#
6 ps脚本我是这样的
如果是windows 参数名和值之间是 空格 而不是=, 这点似乎文档不对。
另外任务里面的
WorkingDirectory
不确定\
行不行。已照此设置,问题依旧。
发现可能是程序需要使用Console对象或者User Profile的bug。
直接启动时,或者计划任务设置为Run only when user is logged on时,窗口会自动打开,所以Console对象是可以获得的。
但计划任务设置成Run whether user is logged on or not,这时候没有Profile,也不会允许打开窗口,程序就直接崩溃。
由于程序不写日志也不留日志文件,具体怎样就只能让开发者自己看了。