Clustering

To get clustering working in Akkatecture, you need to install Akkatecture's companion package called Akkatecture.Clustering to your .net project. This library includes some factories to get your clustered actorsystem going, without doing any changes to your domain code (as it should be). To install the NuGet package from package manager command prompt:

//Add the Akkatecture.Clustering package to your project named FirstAkkatectureProject.
PM> Install-Package Akkatecture.Clustering -ProjectName FirstAkkatectureProject

To start an aggregate manager in a clustered environment, you need to use the ClusterFactory<,,>.StartAggregateCluster(...) method as follows:

//on worker node
var userAccountAggregateManagerCluster = ClusterFactory<UserAccountAggregateManager, UserAccountAggregate, UserAccountId>
.StartAggregateCluster(actorSystem);

The above method invocation will start the actual cluster on that particular node, in addition to returning an IActorRef. It is usually suitable to do this on beefy worker nodes which are responsible for carrying out the more intense units of computation in your application.

To start a proxy to the aggregate manager in a clustered environment, you need to use the ClusterFactory<,,>.StartAggregateClusterProxy(...) method as follows:

//on clientside node
var userAccountAggregateManagerProxy = ClusterFactory<UserAccountAggregateManager, UserAccountAggregate, UserAccountId>
.StartAggregateClusterProxy(actorSystem, proxyRoleName);

This will start a proxy into a userAccountAggregateManagerCluster. The reference returned by this factory method is a reference to the actual cluster. One would typically proxy commands into a cluster from a client application (api or console or desktop app). All commands for that aggregate manager sent through that proxy reference will be sharded accordingly.

Similarly, to start an aggregate saga manager in a clustered environment, use the ClusterFactory<,,,>.StartAggregateSagaCluster(...) to instantiate the saga manager:

//on worker node
ClusterFactory<MoneyTransferSagaManager, MoneyTransferSaga, MoneyTransferSagaId, MoneyTransferSagaLocator>
.StartAggregateSagaCluster(actorSystem,moneyTransferSagaFactory, proxyRoleName);

We usually do not need to get a reference to proxy into the aggregate saga manager because they are invoked through domain events. If you instantiate a saga cluster on the worker that would be enough.

Clustering is a huge concept with many moving parts, in the meantime, refer to the akka.net documentation on clustering if you want more configuration power. If you want to see a working Akkatecture clustering sample, have a look at the cluster sample Which makes use of Akkatecture.Cluster factory methods.