相关疑难解决方法(0)

调用批处理文件后,服​​务在WaitForExit处挂起

我有一个服务有时会调用批处理文件.批处理文件需要5-10秒才能执行:

System.Diagnostics.Process proc = new System.Diagnostics.Process(); // Declare New Process
    proc.StartInfo.FileName = fileName;
    proc.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
    proc.StartInfo.CreateNoWindow = true;
    proc.Start();
    proc.WaitForExit();
Run Code Online (Sandbox Code Playgroud)

当我在控制台中运行相同的代码时,该文件确实存在并且代码可以正常工作.然而,当它在服务内部运行时,它会挂起WaitForExit().我必须从Process中删除批处理文件才能继续.(我确定该文件存在,因为我可以在进程列表中看到它.)

我该如何修复这个挂断?

更新#1:

凯文的代码允许我获得输出.我的一个批处理文件仍然挂起.

"C:\ EnterpriseDB\Postgres\8.3\bin\pg_dump.exe"-i -h localhost -p 5432 -U postgres -F p -a -D -v -f"c:\ backupcasecocher\backupdateevent2008.sql"-t "\"public \".\"dateevent \"""DbTest"

另一个批处理文件是:

"C:\ EnterpriseDB\Postgres\8.3\bin\vacuumdb.exe"-U postgres -d DbTest

我检查了路径,postgresql路径很好.输出目录确实存在,仍然可以在服务外部运行.有任何想法吗?

更新#2:

而不是批处理文件的路径,我写了"C:\ EnterpriseDB\Postgres\8.3\bin\pg_dump.exe"并为其proc.StartInfo.FileName添加了所有参数proc.StartInfo.Arguments.结果没有变化,但我pg_dump.exe在进程窗口中看到了.同样,这只发生在服务中.

更新#3:

我已经与管理员组中的用户一起运行该服务,但无济于事.我恢复null了服务的用户名和密码

更新#4:

我创建了一个简单的服务来在事件日志中编写跟踪并执行包含"dir"的批处理文件.它现在将挂起proc.Start();- 我尝试将帐户从LocalSystem更改为User,我设置了admnistrator用户和密码,仍然没有.

.net c# service windows-services

18
推荐指数
2
解决办法
7万
查看次数

在c#中创建批处理文件

这是我第一次创建批处理.基本上我想在命令Promt中写命令.所以我需要批处理文件,以便我可以在c#中完成任务.

命令如下所示:

install PortName=COM50-
bcdedit.exe -set TESTSIGNING OFF
Run Code Online (Sandbox Code Playgroud)

我如何创建批处理文件并使用c#代码运行它.

谢谢

细节:我使用com0com来创建虚拟端口,所以主要的想法是自动化进程,所以我可以创建端口而无需进入命令端口并编写命令.

c# batch-file com0com

3
推荐指数
2
解决办法
6585
查看次数

标签 统计

c# ×2

.net ×1

batch-file ×1

com0com ×1

service ×1

windows-services ×1