Совместное размещение конечных точек WCF REST и NET.TCP в Azure с помощью ASP.NET

Я размещаю свои службы REST с помощью приложения ASP.NET в Windows Azure. Он работает отлично, но несколько дней назад мне понадобилась служба межролевого общения, я построил свой сервис, но у меня проблемы с его размещением.

Этот код в моем файле Global.asax отлично работает на моем локальном сервере разработки Azure, но не работает в облаке Azure.

Как лучше всего разместить их правильно?

Global.asax:

public class Global : HttpApplication
{
    void Application_Start(object sender, EventArgs e)
    {
        StartNotificationServiceHost();
        RegisterRoutes();
    }

    public ServiceHost ServiceHost { get; private set; }
    private void RegisterRoutes()
    {
        var hostfactory = new WebServiceHostFactory();
        RouteTable.Routes.Add(new ServiceRoute("REST/Companies",hostfactory, typeof(Companies)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Public", hostfactory, typeof(Public)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Users", hostfactory, typeof(Users)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Contacts", hostfactory, typeof(Contacts)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Projects", hostfactory, typeof(Projects)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Instances", hostfactory, typeof(Instances)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Activity", hostfactory, typeof(Activity)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Search", hostfactory, typeof(Search)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Tasks", hostfactory, typeof(Tasks)));
        RouteTable.Routes.Add(new ServiceRoute("REST/Documents", hostfactory, typeof(Documents)));
    }
    private void StartNotificationServiceHost()
    {
        Trace.WriteLine("Starting Service Host", "Information");
        NotificationServiceHost serviceHostBase = new NotificationServiceHost();
        serviceHostBase.RecycleNotificationRecieved += new RecycleNotificationRecievedEventHandler(ServiceHost_RecycleNotificationRecieved);
        serviceHostBase.CheckInstanceStatusRecieved += new CheckInstanceStatusRecievedEventHandler(serviceHostBase_CheckInstanceStatusRecieved);
        ServiceHost = new ServiceHost(serviceHostBase);
        this.ServiceHost.Faulted += (sender, e) =>
        {
            Trace.TraceError("Service Host fault occured");
            this.ServiceHost.Abort();
            Thread.Sleep(500);
            this.StartNotificationServiceHost();

        };
        NetTcpBinding binding = new NetTcpBinding(SecurityMode.None);
        RoleInstanceEndpoint notificationServiceHostEndPoint = RoleEnvironment.CurrentRoleInstance.InstanceEndpoints["NotificationServiceEndPoint"];
        this.ServiceHost.AddServiceEndpoint(
            typeof(INotifyService),
            binding,
            String.Format("net.tcp://{0}/NotifyService", notificationServiceHostEndPoint.IPEndpoint)
            );
        try
        {
            this.ServiceHost.Open();
            Trace.TraceInformation("Service Host Opened");
        }
        catch (TimeoutException timeoutException)
        {
            Trace.TraceError("Service Host open failure, Time Out: " + timeoutException.Message);
        }
        catch (CommunicationException communicationException)
        {
            Trace.TraceError("Service Host open failure, Communication Error: " + communicationException.Message);
        }
        Trace.WriteLine("Service Host Started", "Information");
    }
        InstanceItem serviceHostBase_CheckInstanceStatusRecieved(object sender, int e)
        {
...
        }
        void ServiceHost_RecycleNotificationRecieved(object sender, NotificationMessage e)
        {
...

        }
}

Раздел Web.config / ServiceModel:

  <system.serviceModel>
    <behaviors>
      <serviceBehaviors>
        <behavior>
          <!-- This behavior enables API Key Verification -->
          <serviceAuthorization serviceAuthorizationManagerType="OfisimCRM.Webservice.APIKeyAuthorization, OfisimCRM.Webservice" />
        </behavior>
      </serviceBehaviors>
      <endpointBehaviors>
        <behavior>
          <webHttp />
          <serviceValidator />
        </behavior>
      </endpointBehaviors>
    </behaviors>
    <extensions>
      <behaviorExtensions>
        <add name="serviceValidator" type="OfisimCRM.Webservice.WebHttpWithValidationBehaviorExtension, OfisimCRM.Webservice, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />
      </behaviorExtensions>
    </extensions>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" aspNetCompatibilityEnabled="true" />
    <standardEndpoints>
      <webHttpEndpoint>
        <!-- 
            Configure the WCF REST service base address via the global.asax.cs file and the default endpoint 
            via the attributes on the <standardEndpoint> element below
        -->
        <standardEndpoint crossDomainScriptAccessEnabled="true" faultExceptionEnabled="true" hostNameComparisonMode="WeakWildcard" name="" defaultOutgoingResponseFormat="Json" helpEnabled="true" automaticFormatSelectionEnabled="true" maxBufferSize="65536" maxReceivedMessageSize="104857600" transferMode="Streamed" />
      </webHttpEndpoint>
    </standardEndpoints>
  </system.serviceModel>

ServiceDefinition / WebRole:

 <WebRole name="OfisimCRM.WebClient" vmsize="Small">
    <Sites>
      <Site name="Web">
        <Bindings>
          <Binding name="Endpoint1" endpointName="Endpoint1" />
        </Bindings>
      </Site>
    </Sites>
    <Endpoints>
      <InputEndpoint name="Endpoint1" protocol="http" port="80" />
      <InternalEndpoint name="NotificationServiceEndPoint" protocol="tcp" />
    </Endpoints>
    <Imports>
      <Import moduleName="Diagnostics" />
      <Import moduleName="RemoteAccess" />
    </Imports>
    <ConfigurationSettings>
    </ConfigurationSettings>
  </WebRole>

Ошибка:

The server encountered an error processing the request. The exception message is 'Could not connect to net.tcp://x.x.x.29:8000/NotifyService. The connection attempt lasted for a time span of 00:00:21.0918600. TCP error code 10060: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond x.x.x.29:8000. '. See server logs for more details.
0
задан iboware 9 February 2012 в 00:00
поделиться