草庐IT

c# - .NET Windows 服务的奇怪问题

coder 2024-05-30 原文

我有两个使用 C# 编写的 Windows 服务,它们遵循相同的模式和方法。

这两种服务都针对 Windows 7 VM 进行了开发测试,并在 Windows Server 2008 VM 上进行了 QA 测试。这两项服务已在这些测试环境下多次安装和卸载,没有问题,但在生产环境 (Windows Server 2008) 中安装后,这两项服务之一拒绝启动。

要安装服务,我们使用 InstallUtil.exe 以及附加到服务的 ServiceInstaller 和 ServiceProcessInstaller 组件。

从表面上看,失败的服务安装成功。 InstallUtil.exe 报告成功并且该服务出现在服务管理单元中。您还可以在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Blah Blah 下的注册表中找到该服务。但是,如果您尝试启动该服务,您会得到以下信息:

网络启动 blah.blah.exe “服务名称无效。”

...或通过服务管理单元... “Windows 无法在本地计算机上启动“Blah Blah”服务。错误 1053:该服务未及时响应启动或控制请求。”

我已将一些事件记录添加到服务类失败服务的构造函数中,但它似乎没有被调用。

由于这是一个生产盒子,盒子上没有 Visual Studio,远程调试是不可能的。

是否有任何其他方法可以让我获得关于为什么失败的服务没有启动的调试信息?

我可能会遇到此类问题还有其他明显的原因吗?

编辑:我还应该提到.. Windows 事件查看器中存在问题的唯一其他证据是来自服务控制管理器的系统日志中的两条消息:

“等待 Blah Blah 服务连接时超时(30000 毫秒)。

“由于以下错误,Blah Blah 服务无法启动: 该服务未及时响应启动或控制请求。”

编辑:已解决 该问题最终成为配置错误和隐藏错误的组合。看我的answer下文了解更多详情。

最佳答案

Jeopardy Answer:“无效的自定义配置与错误的全局异常处理程序相结合如何在 .NET Windows 服务中表现出来?”

想通了。

问题的根本原因是 app.config 中的自定义配置部分无效。我们使用自定义配置部分从 app.config 配置服务,ConfigurationSection 派生类的程序集和命名空间最近发生了变化。

事实证明,我们的生产配置正在错误的程序集中寻找自定义 ConfigurationSection 的定义,并且在未能实例化它时抛出的异常被一个错误隐藏了,在该错误中,在服务生命周期的早期捕获异常会尝试记录到自定义日志而不是应用程序事件日志。 (由于自定义事件日志中不存在事件日志源,这会从全局异常处理程序中抛出另一个异常,并且服务会在构造函数中终止。)

第二个异常没有记录在任何地方,我们只是通过代码检查发现的。

解决方案是修复配置并修改全局异常处理程序,使其仅尝试使用服务名称作为事件日志源来写入应用程序事件日志。 (InstallUtil 将服务名称注册为应用程序日志中的事件日志源。)

感谢大家的帮助!抱歉,这个特定问题最终对我们的设置如此具体。

关于c# - .NET Windows 服务的奇怪问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3346408/

有关c# - .NET Windows 服务的奇怪问题的更多相关文章

  1. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  4. ruby - 通过 rvm 升级 ruby​​gems 的问题 - 2

    尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub

  5. ruby - 通过 RVM (OSX Mountain Lion) 安装 Ruby 2.0.0-p247 时遇到问题 - 2

    我的最终目标是安装当前版本的RubyonRails。我在OSXMountainLion上运行。到目前为止,这是我的过程:已安装的RVM$\curl-Lhttps://get.rvm.io|bash-sstable检查已知(我假设已批准)安装$rvmlistknown我看到当前的稳定版本可用[ruby-]2.0.0[-p247]输入命令安装$rvminstall2.0.0-p247注意:我也试过这些安装命令$rvminstallruby-2.0.0-p247$rvminstallruby=2.0.0-p247我很快就无处可去了。结果:$rvminstall2.0.0-p247Search

  6. ruby - Fast-stemmer 安装问题 - 2

    由于fast-stemmer的问题,我很难安装我想要的任何ruby​​gem。我把我得到的错误放在下面。Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingfast-stemmer:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcreatingMakefilemake"DESTDIR="cleanmake"DESTDIR=

  7. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  8. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  9. ruby - 安装 Ruby 时遇到问题(无法下载资源 "readline--patch") - 2

    当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub

  10. c# - 如何在 ruby​​ 中调用 C# dll? - 2

    如何在ruby​​中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL

随机推荐