0
我的WCF服務是這樣工作的:你可以通過調用一個服務方法來訂閱它們,比如說Subscribe()。他們會將您的結果發回給回調通道,說MessageReceived(字符串消息)。我現在的問題是,我的路由器只將第一個Subscribe呼叫路由到其端點列表中的第一個服務。因此,我只從一個服務端點獲取回調消息,而不是兩者。我希望訂閱兩個端點並從兩個端點獲取回調。這裏是我的代碼(注意,我在serviceAddresses線二的net.tcp地址):如何在一對多場景中使用IDuplexSessionRouter?
private void StartAggregatorHost(List<string> serviceAddresses)
{
// Create a new service host for the routing service (note that RoutingService is a pre-defined Microsoft service model type which routes SOAP messages).
aggregatorHost = new ServiceHost(typeof(RoutingService));
// Set up the router address. A logger client will now connect to this address to get logged messages.
string fqdn = System.Net.Dns.GetHostEntry("localhost").HostName;
string routerAddress = string.Format("net.tcp://{0}:2099/LogAggregator", fqdn);
// Set up our router binding.
NetTcpBinding routerBinding = new NetTcpBinding(SecurityMode.None, true);
routerBinding.SendTimeout = new TimeSpan(0, 1, 0);
routerBinding.ReceiveTimeout = new TimeSpan(25, 0, 0);
routerBinding.MaxReceivedMessageSize = int.MaxValue;
routerBinding.MaxConnections = int.MaxValue;
routerBinding.ListenBacklog = int.MaxValue;
routerBinding.ReliableSession.Enabled = true;
routerBinding.ReliableSession.Ordered = true;
routerBinding.ReliableSession.InactivityTimeout = new TimeSpan(15, 0, 0, 0);
// Define the type of router in use. For duplex sessions like in our case, we want to use the IDuplexSessionRouter.
Type contractType = typeof(IDuplexSessionRouter);
// Add the endpoint that the router will use to recieve and relay messages. Note the use of System.ServiceModel.Routing.IDuplexSessionRouter.
aggregatorHost.AddServiceEndpoint(contractType, routerBinding, routerAddress);
// Create the endpoint list that contains the service endpoints we want to route to.
List<ServiceEndpoint> endpointList = new List<ServiceEndpoint>();
foreach (string serverAddress in serviceAddresses)
{
// Set up our server binding(s) for each server.
NetTcpBinding serverBinding = new NetTcpBinding(SecurityMode.None, true);
serverBinding.SendTimeout = new TimeSpan(0, 1, 0);
serverBinding.ReceiveTimeout = new TimeSpan(25, 0, 0);
serverBinding.MaxReceivedMessageSize = int.MaxValue;
serverBinding.MaxConnections = 1;
serverBinding.ListenBacklog = int.MaxValue;
serverBinding.ReliableSession.Enabled = true;
serverBinding.ReliableSession.Ordered = true;
serverBinding.ReliableSession.InactivityTimeout = new TimeSpan(15, 0, 0, 0);
// Create the server endpoint the router will route messages to and from.
ContractDescription contract = ContractDescription.GetContract(contractType);
ServiceEndpoint server = new ServiceEndpoint(contract, serverBinding, new EndpointAddress(serverAddress));
// Add the server to the list of endpoints.
endpointList.Add(server);
}
// Create a new routing configuration object.
RoutingConfiguration routingConfiguration = new RoutingConfiguration();
// Add a MatchAll filter to the Router's filter table. Map it to the endpoint list defined earlier. When a message matches this filter, it will be sent to the endpoint contained in the list.
routingConfiguration.FilterTable.Add(new MatchAllMessageFilter(), endpointList);
// Attach the behavior to the service host.
aggregatorHost.Description.Behaviors.Add(new RoutingBehavior(routingConfiguration));
// Open the service host.
aggregatorHost.Open();
m_eventLog.WriteEntry(string.Format("Log aggregator service hosted at {0}.", routerAddress), EventLogEntryType.Information);
}
所以再次...這就是我想要的:
CLIENT ---REQ---> ROUTER ---REQ---> SVC1
---REQ---> SVC2
CLIENT <---CALLBACK1--- ROUTER <---CALLBACK1--- SVC1
<---CALLBACK2--- <---CALLBACK2--- SVC2
這是我現在得到:
CLIENT ---REQ---> ROUTER ---REQ---> SVC1
CLIENT <---CALLBACK--- ROUTER <---CALLBACK--- SVC1
這是怎麼回事?從我看過的所有例子來看,這應該起作用,不是嗎?!我知道我的服務器地址是正確的,只是碰巧總是選擇第一個可用的地址! – Alexandru
看看這個[由IDesign發佈/訂閱框架](http://idesign.net/Downloads/GetDownload/1897)。 –
@PetarVučetin - 此框架不使用RoutingService。 – Alexandru