Azure Service Bus Relay Periodical Disconnection

时间:2015-04-27 06:52:04

标签: c# wcf azure tcp

我正在使用Azure Service Bus Relay实现一个服务主机。实施非常直接:

的Program.cs:

public class Program
{
    public static void Main(string[] args)
    {
        var random = new Random(Environment.TickCount);

        ServiceHost sh = new ServiceHost(typeof(ProblemSolver));

        var endpoint = sh.Description.Endpoints[0];
        var serviceRegistrySettings = new ServiceRegistrySettings(DiscoveryType.Public);
        endpoint.Behaviors.Add(serviceRegistrySettings);
        string randomText = random.Next().ToString();
        var listenUri = new Uri(endpoint.Address.Uri, randomText  + "/");
        endpoint.ListenUri = listenUri;

        sh.Open();
        Console.WriteLine("Hosted: " + randomText);
        Console.ReadLine();
        sh.Close();
    }
}

的app.config:

<bindings>
  <netTcpRelayBinding>
    <binding name="default">
      <security mode="None" relayClientAuthenticationType="RelayAccessToken" />
    </binding>
  </netTcpRelayBinding>
</bindings>
<services>
  <service name="RelayPrototype.ProblemSolver">
    <endpoint contract="RelayServiceContract.IProblemSolver"
              binding="netTcpRelayBinding"
              bindingConfiguration="default"
              address="sb://test.servicebus.windows.net/problemSolver/"
              listenUri ="sb://test.servicebus.windows.net/problemSolver/"
              behaviorConfiguration="sbTokenProvider"/>
  </service>
</services>
<behaviors>
  <endpointBehaviors>
    <behavior name="sbTokenProvider">
      <transportClientEndpointBehavior>
        <tokenProvider>
          <sharedAccessSignature keyName="RootManageSharedAccessKey" key="[mykey]" />
        </tokenProvider>
      </transportClientEndpointBehavior>
    </behavior>
  </endpointBehaviors>
</behaviors>

我面临的问题是,托管后,它会在2分钟的间隔后定期断开连接。

此时,服务主机的TCP状态从ESTABLISHED更改为CLOSE_WAIT。

监控TCP流量,我发现源ns-sb2-prod-sg3-001.cloudapp.net发送了一个包含FIN标志的数据包,我怀疑它可能导致断开连接。

服务主机将在一段时间后再次尝试建立与Azure的连接。一旦再次建立连接,断开循环就会继续。

但是,此方案仅在我的本地计算机上发生。该服务在其他环境设置中的机器上托管良好。

这可能是我对服务主机的实现还是与本地网络有关?

2 个答案:

答案 0 :(得分:0)

  

这可能是我对服务主机的实现还是与本地网络有关?

如果您看到发送FIN意味着实体(客户端和服务器)故意关闭连接。因此在应用程序的实现而不是与网络。过渡到关闭等待意味着收到并确认了FIN,收到FIN的一方需要致电close

答案 1 :(得分:0)

解决了上述问题。看来中继服务使用TCP端口5671与Azure通信。我们的网络防火墙没有打开该端口,因此强制关闭已建立的连接。因此,应打开TCP端口5671以与Azure通信。