简体   繁体   English

AKKA远程演员错误

[英]AKKA Remote Actor Error

I am trying to run an AKKA remote example by 我正在尝试通过运行AKKA远程示例

1. Running the remote actor in a machine with IP 192.168.1.7
2. Running the local from my machine

The remote actor is started up in the machine (with ip address 192.168.1.7); 远程角色在计算机中启动(IP地址为192.168.1.7); but when I start Local actor from my machine, its not able to connect to the remote actor. 但是当我从机器启动Local actor时,它无法连接到远程actor。 Please find the Local and Remote actor system configuration: 请找到本地和远程actor系统配置:

Local: 本地:

akka {
  //loglevel = "INFO"
  actor {
    provider = "akka.remote.RemoteActorRefProvider"
  }
  remote {
    enabled-transports = ["akka.remote.netty.tcp"]
    netty.tcp {
      hostname = "127.0.0.1"
      port = 0
    }
    //log-sent-messages = on
    //log-received-messages = on
  }
}

Remote: 远程:

akka {
  //loglevel = "INFO"
  actor {
    provider = "akka.remote.RemoteActorRefProvider"
  }
  remote {
    enabled-transports = ["akka.remote.netty.tcp"]
    netty.tcp {
      hostname = "127.0.0.1"
      port = 5150
    }
    //log-sent-messages = on
    //log-received-messages = on
  }
}

Code in the local system to connect to remote actor: 本地系统中的代码以连接到远程actor:

class LocalActor extends Actor {
  val remote = context.actorFor("akka.tcp://HelloRemoteSystem@192.168.1.7:5150/user/RemoteActor")
  var counter = 0
  def receive = {
    case "START" => 
        remote ! "Hello from the LocalActor"
    case msg: String => 
        println(s"LocalActor received message: '$msg'")
        if (counter < 5) {
            sender ! "Hello back to you"
            counter += 1
        }
  }
}  

When I start the local system, I get the below Message: 启动本地系统时,收到以下消息:

C:\Users\AnandKrishnan\Documents\GitHub\AkkaRemoteActorsHelloWorld\HelloLocal [master +0 ~5 -0]> sbt run
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=256m; support was removed in 8.0
[info] Set current project to HelloLocal (in build file:/C:/Users/AnandKrishnan/Documents/GitHub/AkkaRemoteActorsHelloWorld/HelloLocal/)
[info] Compiling 1 Scala source to C:\Users\AnandKrishnan\Documents\GitHub\AkkaRemoteActorsHelloWorld\HelloLocal\target\scala-2.11\classes...
[warn] there was one deprecation warning; re-run with -deprecation for details
[warn] one warning found
[info] Running local.Local
[INFO] [02/14/2016 22:57:11.755] [run-main-0] [Remoting] Starting remoting
[INFO] [02/14/2016 22:57:12.163] [run-main-0] [Remoting] Remoting started; listening on addresses :[akka.tcp://LocalSystem@127.0.0.1:50830]
[INFO] [02/14/2016 22:57:12.163] [run-main-0] [Remoting] Remoting now listens on addresses: [akka.tcp://LocalSystem@127.0.0.1:50830]
[WARN] [02/14/2016 22:57:13.351] [LocalSystem-akka.remote.default-remote-dispatcher-5] [akka.tcp://LocalSystem@127.0.0.1:50830/system/endpointManager/reliableEndpointWriter-akka.tcp
%3A%2F%2FHelloRemoteSystem%40192.168.1.7%3A5150-0/endpointWriter] AssociationError [akka.tcp://LocalSystem@127.0.0.1:50830] -> [akka.tcp://HelloRemoteSystem@192.168.1.7:5150]: Error
 [Invalid address: akka.tcp://HelloRemoteSystem@192.168.1.7:5150] [
akka.remote.InvalidAssociation: Invalid address: akka.tcp://HelloRemoteSystem@192.168.1.7:5150
Caused by: akka.remote.transport.Transport$InvalidAssociationException: Connection refused: no further information: /192.168.1.7:5150
]
[WARN] [02/14/2016 22:57:13.371] [LocalSystem-akka.remote.default-remote-dispatcher-6] [Remoting] Tried to associate with unreachable remote address [akka.tcp://HelloRemoteSystem@192.168.1.7:5150]. Address is now gated for 5000 ms, all messages to this address will be delivered to dead letters. Reason: Connection refused: no further information: /192.168.1.7:5150
[INFO] [02/14/2016 22:57:13.389] [LocalSystem-akka.actor.default-dispatcher-3] [akka://LocalSystem/deadLetters] Message [java.lang.String] from Actor[akka://LocalSystem/user/LocalActor#1441959988] to Actor[akka://LocalSystem/deadLetters] was not delivered. [1] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'akka.log-dead-letters' and 'akka.log-dead-letters-during-shutdown'.

In the Remote Actor class you have: 在Remote Actor类中,您具有:

val system = ActorSystem("HelloRemoteSystem", config)

Make sure that in the Local actor when using actorSelection / actorFor you use the same name like: 确保在使用actorSelection / actor时在本地actor中使用actorFor您相同的名称,例如:

val remoteActor = context.actorSelection("akka.tcp://HelloRemoteSystem@127.0.0.1:2553/user/RemoteActor")

In order for an Akka actor system to communicate with other hosts, the actor system must bind to a hostname or IP that is routable by the other host in question. 为了使Akka actor系统与其他主机进行通信,actor系统必须绑定到所讨论的其他主机可路由的主机名或IP。 localhost , of course, is not. localhost当然不是。

Your remote system needs to bind to 192.168.1.7: 您的远程系统需要绑定到192.168.1.7:

akka {
  remote {
    netty.tcp {
      hostname = "192.168.1.7"
    }
  }
}

Of course in production you'll likely want to use hostnames rather than IPs. 当然,在生产中,您可能希望使用主机名而不是IP。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM