2016-07-04 13 views
1
akka { 
    actor { 
    provider = "akka.cluster.ClusterActorRefProvider" 
    } 
    remote { 
    enabled-transports = ["akka.remote.netty.tcp"] 
    netty.tcp { 
     hostname = "127.0.0.1" 
     port = 0 
    } 
    } 
} 

akka.cluster { 
    seed-nodes = [ 
    "akka.tcp://[email protected]:2551", 
    "akka.tcp://[email protected]:2552" 
    ] 
} 

object AndromedaApiClusterActivator extends App { 
    val system = ActorSystem("MyCluster", ConfigFactory.load()) 
    val clusterController = system.actorOf(Props[MyCluster], name = "MyCluster") 
} 


class MyCluster extends Actor { 

    val log = Logging(context.system, this) 
    val cluster = Cluster(context.system) 

    override def preStart() { 
    cluster.subscribe(self, classOf[MemberEvent], classOf[UnreachableMember]) 
    } 

    override def postStop() { 
    cluster.unsubscribe(self) 
    } 

    override def receive = { 
    case x: MemberEvent => log.info("MemberEvent: {}", x) 
    case x: UnreachableMember => log.info("UnreachableMember {}: ", x) 
    } 

} 

Wenn ich es laufen erhalte ich:Akka: Wie starte ich einen einfachen lokalen Cluster?

Association with remote system [akka.tcp://[email protected]:2552] has failed, address is now gated for [5000] ms. Reason: [Association failed with [akka.tcp://[email protected]:2552]] Caused by: [Connection refused: /127.0.0.1:2552] 
Association with remote system [akka.tcp://[email protected]:2551] has failed, address is now gated for [5000] ms. Reason: [Association failed with [akka.tcp://[email protected]:2551]] Caused by: [Connection refused: /127.0.0.1:2551] 

Ich kann keine Erklärung finden. Irgendeine Hilfe?

+0

überprüfen in Dieser Link https://groups.google.com/forum/#!topic/akka-user/joTgQ6PDX0Y – aravindKrishna

Antwort

1

Sie sollten zuerst 2 Knoten starten und dann eine Verbindung zu ihnen herstellen. Um es zu veranschaulichen, werde ich beide Systeme innerhalb einer App erstellen, aber Sie können 2 Instanzen der App mit anderen Konfigurationen/Ports in der Befehlszeile ausgeführt ausführen.

object Main extends App { 
    val system1 = ActorSystem("MyCluster1", ConfigFactory.load("node1.conf")) 
    val system2 = ActorSystem("MyCluster2", ConfigFactory.load("node2.conf")) 
    val clusterController = system1.actorOf(Props[MyCluster], name = "MyCluster1") 
} 

application.conf:

akka { 
    actor { 
    provider = "akka.cluster.ClusterActorRefProvider" 
    } 
    remote { 
    enabled-transports = ["akka.remote.netty.tcp"] 
    netty.tcp { 
     hostname = "127.0.0.1" 
     port = 2552 
    } 
    } 
} 

akka.cluster { 
    seed-nodes = [ 
    "akka.tcp://[email protected]:2552", 
    "akka.tcp://[email protected]:2553" 
    ] 
} 

anderen Knoten zu starten, schlage ich verschiedene Konfigurationen mit node1.conf angeben:

include "application" 

akka.remote.netty.tcp.port = 2552 

node2.conf:

include "application" 

akka.remote.netty.tcp.port = 2553