如何从Windows服务捕获标准错误输出?

时间:2009-05-06 17:45:03

标签: c++ windows service ldap

我有一个使用Mozilla LDAP库的应用程序。我们正在诊断涉及LDAP库无法与服务器建立连接的问题。我试图通过在应用程序中调试lib的调试版本并使用ldap_set_opt启用调试来从LDAP库获取其他信息。不幸的是,我认为调试库正在将调试字符串发送到标准错误。

当我正在重新编译LDAP客户端库时,希望启用使其调用OutputDebugString而不是流式传输到stderr的选项,一个不错的解决方案是将stderr输出捕获到文件。但是,该应用程序作为Windows服务运行。

任何人都知道我如何将stderr重定向到作为服务运行的应用程序的文件?

修改

我希望不必修改任何比我已有的服务源代码更多的服务源代码。服务配置中的选项是理想的。

2 个答案:

答案 0 :(得分:5)

如果要修改服务代码,可以在ServiceMain中调用SetStdHandle

SetStdHandle(STD_ERROR_HANDLE, logFileHandle);

答案 1 :(得分:5)

您可以尝试手动重定向stderr吗?

    FILE* stderr_redirect = freopen( "C:/stderr.log", "w", stderr );

    // Code that writes to stderr

    fclose( stderr_redirect );

编辑:

除了自己处理服务中的流之外,没有办法为服务重定向stdout或stderr。某些服务提供了将这些消息重定向到文件的选项。您可以临时重定向这些流,也可以向服务添加一个选项,以便在下次出现问题时对其进行配置。

相关问题