我正在使用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的连接。一旦再次建立连接,断开循环就会继续。
但是,此方案仅在我的本地计算机上发生。该服务在其他环境设置中的机器上托管良好。
这可能是我对服务主机的实现还是与本地网络有关?
答案 0 :(得分:0)
这可能是我对服务主机的实现还是与本地网络有关?
如果您看到发送FIN意味着实体(客户端和服务器)故意关闭连接。因此在应用程序的实现而不是与网络。过渡到关闭等待意味着收到并确认了FIN,收到FIN的一方需要致电close
。
答案 1 :(得分:0)
解决了上述问题。看来中继服务使用TCP端口5671与Azure通信。我们的网络防火墙没有打开该端口,因此强制关闭已建立的连接。因此,应打开TCP端口5671以与Azure通信。