/// <summary> /// This is the entry point of the service host process. /// </summary> private static void Main() { try { // This line registers an Actor Service to host your actor class with the Service Fabric runtime. // The contents of your ServiceManifest.xml and ApplicationManifest.xml files // are automatically populated when you build this project. // For more information, see https://aka.ms/servicefabricactorsplatform ActorRuntime.RegisterActorAsync <SampleActorSubscriber>( (context, actorType) => new SampleActorSubscriberService( context, actorType, (actorService, actorId) => new SampleActorSubscriber(actorService, actorId))).GetAwaiter().GetResult(); ISampleActorSubscriber actorSubscriber; if (FabricConfiguration.UseCustomServiceRemotingClientFactory) { actorSubscriber = FabricConfiguration.GetProxyFactories().CreateActorProxy <ISampleActorSubscriber>(new Uri("fabric:/PubSubDemo/SampleActorSubscriberService"), ActorId.CreateRandom()); } else { actorSubscriber = ActorProxy.Create <ISampleActorSubscriber>(ActorId.CreateRandom(), new Uri("fabric:/PubSubDemo/SampleActorSubscriberService")); } actorSubscriber.Subscribe().GetAwaiter().GetResult(); Thread.Sleep(Timeout.Infinite); } catch (Exception e) { ActorEventSource.Current.ActorHostInitializationFailed(e.ToString()); throw; } }
public Broker(StatefulServiceContext context) : base(context, proxyFactories: FabricConfiguration.GetProxyFactories()) { ServiceEventSourceMessageCallback = message => ServiceEventSource.Current.ServiceMessage(context, message); Period = TimeSpan.FromMilliseconds(200); }