繁体   English   中英

Windows Server 2012 R2上的意外崩溃WCF服务

[英]Unexpected crash WCF Service on Windows Server 2012 R2

这将是很长的篇幅,因为我想尽可能多地解释并详细说明我的问题。 我是后端开发的新手,现在正在开发使用WCF,C#和.NET Framework 4.5的安全(https)REST Web服务。 对于这种情况,我使用在IIS中配置的自签名证书。 我的问题是,服务主机似乎随机崩溃,没有任何异常或跟踪日志中的消息。 我在Windows Server 2012 R2的VMware中对其进行了测试。 在其他操作系统(WS 2008,WS 2010)上似乎可以正常工作。 这是我通过将EventHandler注册为Faulted状态来启动服务的方法:

private ServiceHost listener = null;

public void Start(byte[] certData, string certPassword) {
    int port = Config.MobileServicePort;

    SslCertificate cert = new SslCertificate();

    cert.RemoveCertificate(port);
    cert.InstallCertificate(port, certData, certPassword);

    Uri uri = new Uri(string.Format("https://127.0.0.1:{0}/{1}", port, "MobileService"));

    if (listener != null) {
        listener.Close();
        listener = null;
    }

    listener = new ServiceHost(typeof(MobileService), uri);
    listener.Faulted += FaultedStateHandling;

    try {
        listener.Open();
        Logger.System().Info("REGISTER service at '{0}'", uri.ToString());
    } catch (TimeoutException timeEx) {
        Logger.System().Error("Open timeout exception: " + timeEx);
    } catch (CommunicationException comEx) {
        Logger.System().Error("Open communication exception: " + comEx);
    } catch (Exception ex) {
        Logger.System().Error(ex);
    }
}

这是故障状态的处理程序:

private void FaultedStateHandling(object sender, EventArgs e) {
    try {
        Logger.System().Info("<------------***Mobile service Faulted****------------>");
        listener.Abort();
        listener.Faulted -= new EventHandler(FaultedStateHandling);
        int port = Config.MobileServicePort;
        Uri uri = new Uri(string.Format("https://127.0.0.1:{0}/{1}", port, "MobileService"));
        listener = new ServiceHost(typeof(MobileService), uri);
        listener.Faulted += new EventHandler(FaultedStateHandling);
        listener.Open();
        Logger.System().Info("<------------***Mobile service Restarted****------------>");
    } catch (Exception ex) {
        Logger.System().Error(ex);
    }
}

这是我为MessageLogging和Tracing配置的app.config

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.diagnostics>
     <sources>
      <source name="System.ServiceModel"
              switchValue="Critical,Information,ActivityTracing"
              propagateActivity="true">
        <listeners>
          <add name="messages"
          type="System.Diagnostics.XmlWriterTraceListener"
          initializeData="c:\log\TraceMessages.svclog" />
        </listeners>
      </source>

       <source name="System.ServiceModel.MessageLogging">
         <listeners>
           <add name="messages"
                type="System.Diagnostics.XmlWriterTraceListener"
                initializeData="c:\log\MessageLogging.svclog" />
         </listeners>
      </source>

   </sources>
    <trace autoflush="true" />
  </system.diagnostics>

<system.serviceModel>
  <diagnostics>
    <messageLogging
          logEntireMessage="false"
          logMalformedMessages="true"
          logMessagesAtServiceLevel="true"
          logMessagesAtTransportLevel="false"
          maxMessagesToLog="500"
          maxSizeOfMessageToLog="5000"/>
  </diagnostics>
<services>
  <service behaviorConfiguration="MobileBehavior"     name="noq.Mobile.Service.MobileService">
    <endpoint address="" binding="webHttpBinding" 
                         bindingConfiguration="webHttpTransportSecurity" 
                         behaviorConfiguration="REST"
                         contract="noq.Mobile.Service.IMobileService">
      <identity>
        <dns value="localhost" />
      </identity>
    </endpoint>
    <endpoint address="mex"  
              binding="mexHttpsBinding" 
              contract="IMetadataExchange" />
    <!--<host>
      <baseAddresses>
        <add baseAddress="http://localhost:11082/MobileService/" />
      </baseAddresses>
    </host>-->
  </service>
</services>
<bindings>
  <webHttpBinding>
    <binding name="webHttpTransportSecurity" maxBufferSize="1000000000"
      maxReceivedMessageSize="1000000000">
      <readerQuotas maxStringContentLength="1000000000" />
      <security mode="Transport" />
    </binding>
  </webHttpBinding>
</bindings>
<behaviors>
  <endpointBehaviors>
    <behavior name="REST">
      <webHttp />
    </behavior>
  </endpointBehaviors>
  <serviceBehaviors>
    <behavior name="MobileBehavior">
      <serviceMetadata httpGetEnabled="false" httpsGetEnabled="true" />
      <serviceDebug includeExceptionDetailInFaults="true" />
    </behavior>
  </serviceBehaviors>
</behaviors>
 </system.serviceModel>
 <startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
 </startup>
</configuration>

我在此问题上库存了大约1个月,找不到解决方案。 我尝试了许多配置,似乎问题更深了。 我检查了MSDN论坛和support.microsoft。 在那里,我发现了类似的问题,但不一样的,他们提供了一些热修复程序,就像 该问题是否可能与VM配置有关? 在此先感谢您和任何建议。

终于我有了解决方案! 而且我花了太多时间来解决和诊断这样一个愚蠢的问题。 这是我的行为方式:

  1. 运行-> cmd-> eventvwr
  2. 从源HttpEvent获得了一条错误代码为0x8009030D的日志消息。
  3. msdn blog应用了此解决方案。

    现在的问题是:这3个场景中的哪一个解决了我的问题? 第二:如何以编程方式应用此修复程序? 祝好运! 附庸风雅

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM