Typed Distributed Data requires untyped Cluster [#25746](https://github.com/akka/akka/issues/25746)
This commit is contained in:
parent
2c145cd3c3
commit
8a44fca087
44 changed files with 656 additions and 368 deletions
|
|
@ -10,7 +10,7 @@ import akka.actor.ExtendedActorSystem
|
|||
import akka.actor.Extension
|
||||
import akka.actor.ExtensionId
|
||||
import akka.actor.ExtensionIdProvider
|
||||
import akka.cluster.Cluster
|
||||
import akka.cluster.{ Cluster, UniqueAddress }
|
||||
|
||||
object DistributedData extends ExtensionId[DistributedData] with ExtensionIdProvider {
|
||||
override def get(system: ActorSystem): DistributedData = super.get(system)
|
||||
|
|
@ -28,14 +28,9 @@ object DistributedData extends ExtensionId[DistributedData] with ExtensionIdProv
|
|||
*/
|
||||
class DistributedData(system: ExtendedActorSystem) extends Extension {
|
||||
|
||||
private val config = system.settings.config.getConfig("akka.cluster.distributed-data")
|
||||
private val settings = ReplicatorSettings(config)
|
||||
private val settings = ReplicatorSettings(system)
|
||||
|
||||
/**
|
||||
* Returns true if this member is not tagged with the role configured for the
|
||||
* replicas.
|
||||
*/
|
||||
def isTerminated: Boolean = Cluster(system).isTerminated || !settings.roles.subsetOf(Cluster(system).selfRoles)
|
||||
implicit val selfUniqueAddress: SelfUniqueAddress = SelfUniqueAddress(Cluster(system).selfUniqueAddress)
|
||||
|
||||
/**
|
||||
* `ActorRef` of the [[Replicator]] .
|
||||
|
|
@ -45,7 +40,20 @@ class DistributedData(system: ExtendedActorSystem) extends Extension {
|
|||
system.log.warning("Replicator points to dead letters: Make sure the cluster node is not terminated and has the proper role!")
|
||||
system.deadLetters
|
||||
} else {
|
||||
val name = config.getString("name")
|
||||
system.systemActorOf(Replicator.props(settings), name)
|
||||
system.systemActorOf(Replicator.props(settings), ReplicatorSettings.name(system, None))
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns true if this member is not tagged with the role configured for the
|
||||
* replicas.
|
||||
*/
|
||||
def isTerminated: Boolean =
|
||||
Cluster(system).isTerminated || !settings.roles.subsetOf(Cluster(system).selfRoles)
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Cluster non-specific (typed vs untyped) wrapper for [[akka.cluster.UniqueAddress]].
|
||||
*/
|
||||
@SerialVersionUID(1L)
|
||||
final case class SelfUniqueAddress(uniqueAddress: UniqueAddress)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue