0

リモートIPアドレスでアクターシステムを初期化するのに問題がありました。アッカ俳優と演劇を使っています!フレームワーク。コードとリモートアクターシステムは両方ともリモートラックスペースサーバー上にあります。他のサーバーにリモートアクターシステムを作成しようとすると、そのIPアドレスにバインドできません。Rackspaceはサーバー間のすべての接続を開いたと言っているので、ネットワークやファイアウォールの問題ではないと思います。これは私が受け取っているエラーメッセージです:

[error] application - 

! Internal server error, for request [POST /payment/] ->

java.lang.ExceptionInInitializerError: null
    at     Routes$$anonfun$routes$1$$anonfun$apply$3$$anonfun$apply$4.apply(routes_routing.scala:44) ~[classes/:na]
    at Routes$$anonfun$routes$1$$anonfun$apply$3$$anonfun$apply$4.apply(routes_routing.scala:44) ~[classes/:na]
    at play.core.Router$HandlerInvoker$$anon$3.call(Router.scala:1080) ~[play_2.9.1-2.0.1.jar:2.0.1]
    at play.core.Router$Routes$class.invokeHandler(Router.scala:1255) ~[play_2.9.1-2.0.1.jar:2.0.1]
    at Routes$.invokeHandler(routes_routing.scala:14) ~[classes/:na]
    at Routes$$anonfun$routes$1$$anonfun$apply$3.apply(routes_routing.scala:44) ~[classes/:na]

Caused by: org.jboss.netty.channel.ChannelException: Failed to bind to: /172.17.100.232:2554
    at org.jboss.netty.bootstrap.ServerBootstrap.bind(ServerBootstrap.java:298) ~[netty-3.3.0.Final.jar:na]
    at akka.remote.netty.NettyRemoteServer.start(Server.scala:53) ~[akka-remote-2.0.2.jar:2.0.2]
    at akka.remote.netty.NettyRemoteTransport.start(NettyRemoteSupport.scala:73) ~[akka-remote-2.0.2.jar:2.0.2]
    at akka.remote.RemoteActorRefProvider.init(RemoteActorRefProvider.scala:95) ~[akka-remote-2.0.2.jar:2.0.2]
    at akka.actor.ActorSystemImpl._start(ActorSystem.scala:568) ~[akka-actor-2.0.2.jar:2.0.2]
    at akka.actor.ActorSystemImpl.start(ActorSystem.scala:575) ~[akka-actor-2.0.2.jar:2.0.2]

Caused by: java.net.BindException: Cannot assign requested address
    at sun.nio.ch.Net.bind(Native Method) ~[na:1.6.0_26]
    at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:126) ~[na:1.6.0_26]
    at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:59) ~[na:1.6.0_26]
    at org.jboss.netty.channel.socket.nio.NioServerSocketPipelineSink.bind(NioServerSocketPipelineSink.java:140) ~[netty-3.3.0.Final.jar:na]
    at org.jboss.netty.channel.socket.nio.NioServerSocketPipelineSink.handleServerSocket(NioServerSocketPipelineSink.java:92) ~[netty-3.3.0.Final.jar:na]
    at org.jboss.netty.channel.socket.nio.NioServerSocketPipelineSink.eventSunk(NioServerSocketPipelineSink.java:66) ~[netty-3.3.0.Final.jar:na]

ここでリモートアクターシステムを作成しています:

object Payment extends Controller {
  var goodies: AuthNetActorObject = null

  val system = ActorSystem("RemoteCreation", ConfigFactory.load.getConfig("remotecreation"))
  val myActor = system.actorOf(Props[authNetActor.AuthNetActorMain], name = "remoteActor")
  ...
}

Application.confファイルでremotecreationを定義する場所は次のとおりです。

remotecreation{ #user defined name for the configuration
    include "common"
    akka {
            actor{
                    #serializer{
                    #       proto = "akka.serialization.ProtobufSerializer"
                    #       daemon-create = "akka.serialization.DaemonMsgCreateSerializer"
                    #}

                    #serialization-bindings{
                    #       "com.google.protobuf.GeneratedMessage" = proto
                    #       "akka.remote.DaemonMsgCreate" = daemon-create
                    #}

                    deployment{
                            /remoteActor{   #Specifically has to be the name of the remote actor
                                    remote="akka://RemoteCreation@172.17.100.232:2554"
                            #       router = "round-robin"
                            #       nr-of-instances = 10
                            #       target {
                            #               nodes = ["akka://RemoteCreation@172.17.100.232:2554", "akka://RemoteCreation@172.17.100.224:2554"]
                            #       }
                            }
                    }
            }
    }
}

これが私が定義に含める私のcommon.confファイルです:

akka {

  actor {
    provider = "akka.remote.RemoteActorRefProvider"
  }

  remote {
        transport = "akka.remote.netty.NettyRemoteTransport"
        log-received-messages = on
        log-sent-messages = on
        log-remote-lifecycle-events = on

    netty {
      hostname = "172.17.100.232"       #Broadcast IP address of remote system
      port = 2554
        log-received-messages = on
        log-sent-messages = on
          log-remote-lifecycle-events = on

    }
  }
}
4

1 に答える 1

1

おそらく、他の何かがそのマシンのそのポートを使用していることを意味します。そのマシンにログインしてnetstat -anp | grep 2554rootとして実行し、ポートがLISTENステータスになっていることを確認します。その場合、プロセスIDは最後の列に表示されます。

于 2012-09-11T21:24:58.343 に答える