1

我创建了一个 WCF 服务,并通过工作角色将其托管在云中。不幸的是,当我尝试连接到辅助角色服务时,我收到一条异常消息:“主机 3a5c0cdffcf04d069dbced5e590bca70.cloudapp.net 不存在 DNS 条目。” 3a5c0cdffcf04d069dbced5e590bca70.cloudapp.net 是部署在 azure 暂存环境中的辅助角色的地址。workerrole.cs 具有以下代码来公开 WCF 服务:

    public override void Run()
    {
        using (ServiceHost host = new ServiceHost(typeof(MyService)))
        {
            string ip = RoleEnvironment.CurrentRoleInstance.InstanceEndpoints["tcppoint"].IPEndpoint.Address.ToString();
            int tcpport = RoleEnvironment.CurrentRoleInstance.InstanceEndpoints["tcppoint"].IPEndpoint.Port;
            int mexport = RoleEnvironment.CurrentRoleInstance.InstanceEndpoints["mexinput"].IPEndpoint.Port;

            // Add a metadatabehavior for client proxy generation
            // The metadata is exposed via net.tcp
            ServiceMetadataBehavior metadatabehavior = new ServiceMetadataBehavior();
            host.Description.Behaviors.Add(metadatabehavior);
            Binding mexBinding = MetadataExchangeBindings.CreateMexTcpBinding();
            string mexlistenurl = string.Format("net.tcp://{0}:{1}/MyServiceMetaDataEndpoint", ip, mexport);
            string mexendpointurl = string.Format("net.tcp://{0}:{1}/MyServiceMetaDataEndpoint", RoleEnvironment.GetConfigurationSettingValue("Domain"), 8001);
            host.AddServiceEndpoint(typeof(IMetadataExchange), mexBinding, mexendpointurl, new Uri(mexlistenurl));

            // Add the endpoint for MyService
            string listenurl = string.Format("net.tcp://{0}:{1}/MyServiceEndpoint", ip, tcpport);
            string endpointurl = string.Format("net.tcp://{0}:{1}/MyServiceEndpoint", RoleEnvironment.GetConfigurationSettingValue("Domain"), 9001);
            host.AddServiceEndpoint(typeof(IMyService), new NetTcpBinding(SecurityMode.None), endpointurl, new Uri(listenurl));
            host.Open();

            while (true)
            {
                Thread.Sleep(100000);
                Trace.WriteLine("Working", "Information");
            }
        }
    } 

tcppoint 和 mexinput 配置了端口 8001 和 9001。Domain 还配置了工作角色部署 url:3a5c0cdffcf04d069dbced5e590bca70.cloudapp.net

在客户端部分(控制台应用程序),我们在 app.config 中使用以下配置:

    <bindings>
        <netTcpBinding>
            <binding name="NetTcpBinding_IMyService" closeTimeout="00:01:00"
                openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
                transactionFlow="false" transferMode="Buffered" transactionProtocol="OleTransactions"
                hostNameComparisonMode="StrongWildcard" listenBacklog="10"
                maxBufferPoolSize="524288" maxBufferSize="65536" maxConnections="10"
                maxReceivedMessageSize="65536">
                <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
                    maxBytesPerRead="4096" maxNameTableCharCount="16384" />
                <reliableSession ordered="true" inactivityTimeout="00:50:00"
                    enabled="false" />
                <security mode="None">
                    <transport clientCredentialType="Windows" protectionLevel="EncryptAndSign" />
                    <message clientCredentialType="Windows" />
                </security>
            </binding>
        </netTcpBinding>

    </bindings>
    <client>
      <endpoint address="httpp:\\3a5c0cdffcf04d069dbced5e590bca70.cloudapp.net:9001/MyServiceEndpoint" binding="netTcpBinding"
         bindingConfiguration="NetTcpBinding_IMyService" contract="ServiceReference1.IMyService"
         name="NetTcpBinding_IMyService" />
    </client>

  <behaviors>
    <serviceBehaviors>
      <behavior name="behave">
        <serviceMetadata httpGetEnabled="false"/>
      </behavior>
    </serviceBehaviors>
  </behaviors>   

</system.serviceModel>
<system.net>
  <defaultProxy useDefaultCredentials="true">
  <proxy autoDetect="False" usesystemdefault="False" bypassonlocal="True" />
</defaultProxy>

以下代码是使用 msdn 中提供的示例代码作为背景构建的。在本地,它工作正常。不幸的是,当我将它部署到云时,会发生异常。此外,当我使用虚拟 ip 而不是 url 时,会发生连接超时,除非远程机器没有响应。

4

2 回答 2

0

看起来你有你的服务设置来监听 net.tcp (TCP) 和你的客户端使用 http 绑定。我不希望它甚至在本地工作。我假设您实际上已经在 ServiceDefinition 中打开了端口 9000。请记住,这将是一个负载平衡的端点。您是尝试从部署内部(角色间)还是从云外部与此实例通信?

我发现通过代码设置主机和客户端(在角色内通信时)要容易得多。尝试这个:

http://dunnry.com/blog/2010/05/28/HostingWCFInWindowsAzure.aspx

如果您尝试从部署之外的客户端访问服务,这仍然适用,但适用于客户端构建部分。您将需要使用在 ServiceDefinition 中定义的外部 DNS 名称和端口。

如果您在角色准备好之前尝试过早地访问端点,我也看到了 DNS 错误。传播 DNS 可能需要一些时间,您应该尽量在它准备好之前不要解析它,以免缓存伪造的 DNS 条目。如果您可以将该 DNS 名称解析为您的 VIP 地址,那不是问题。

于 2011-08-18T17:07:33.500 回答
-2
    public void CallWebService(string data)
    {

        try
        {
            string uri = "url"+data;

            HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(uri);

            HttpWebResponse response = (HttpWebResponse)request.GetResponse();

            Stream str = response.GetResponseStream();

            StreamReader sr = new StreamReader(str);

            String IResponse = sr.ReadToEnd();


        }
        catch (Exception ex)
        {
            System.Console.WriteLine("Message: "+ex.Message);
        }

    }

希望它可以帮助你。

于 2013-05-10T10:12:55.000 回答