NoSuchMethodError: akka.actor.LocalActorRefProvider.log () Lakka / event / LoggingAdapter - PullRequest
0 голосов
/ 01 января 2019

Когда я начинаю простое akka-http-server, я получаю исключение.Я искал по всему Интернету и нашел два решения, которые не работают для меня:

  1. Микширование версий Scala (я проверил мой pom 2.11 Scala без микширования)
  2. Изменить актера Scalaверсия. (Я пробовал почти десять версий с 2.11 Scala)

Я не знаю, как решить эту проблему, пожалуйста, скажите мне, как решить эту проблему.

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

main class
package com.akkademo;
import akka.actor.ActorSystem;
import akka.actor.Props;
import com.typesafe.config.Config;
import com.typesafe.config.ConfigFactory;
public class Main {
    public static void main(String[] args) {
        ActorSystem actorSystem = ActorSystem.create("akkademo", ConfigFactory.load());
        Config config = actorSystem.settings().config();
        actorSystem.actorOf(Props.create(AkkademoDb.class), "akkademo-db");
    }
}

pom.xml
     <properties>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
            <jdk.version>1.8</jdk.version>
            <scala>2.11</scala>

            <scala.version>2.11.8</scala.version>
            <akka.version>2.4.14</akka.version>
            <akka.remote>2.3.6</akka.remote>
            <akka.compat>0.7.0</akka.compat>
            <akka.test>2.5.9</akka.test>
        </properties>
        <dependencies>
            <dependency>
                <groupId>org.junit.jupiter</groupId>
                <artifactId>junit-jupiter-api</artifactId>
                <version>RELEASE</version>
                <scope>compile</scope>
            </dependency>
            <dependency>
                <groupId>com.typesafe.akka</groupId>
                <artifactId>akka-testkit_${scala}</artifactId>
                <version>${akka.test}</version>
            </dependency>
            <dependency>
                <groupId>com.typesafe.akka</groupId>
                <artifactId>akka-remote_${scala}</artifactId>
                <version>${akka.remote}</version>
            </dependency>
            <dependency>
                <groupId>org.scala-lang.modules</groupId>
                <artifactId>scala-java8-compat_${scala}</artifactId>
                <version>${akka.compat}</version>
            </dependency>
            <dependency>
                <groupId>com.typesafe.akka</groupId>
                <artifactId>akka-actor_${scala}</artifactId>
                <version>${akka.version}</version>
            </dependency>
            <dependency>
                <groupId>com.typesafe.akka</groupId>
                <artifactId>akka-slf4j_${scala}</artifactId>
                <version>${akka.version}</version>
            </dependency>
            <dependency>
                <groupId>org.scala-lang</groupId>
                <artifactId>scala-library</artifactId>
                <version>${scala.version}</version>
            </dependency>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.11</version>
            </dependency>

        </dependencies>
        <repositories>
            <repository>
                <id>aliyun</id>
                <name>aliyun</name>
                <url>http://maven.aliyun.com/nexus/content/groups/public</url>
            </repository>
        </repositories>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <version>2.3.2</version>
                    <configuration>
                        <source>${jdk.version}</source>
                        <target>${jdk.version}</target>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    </project>

Исключение в потоке "main" java.lang.NoSuchMethodError: akka.actor.LocalActorRefProvider.log () Lakka / event / LoggingAdapter;в akka.remote.RemoteActorRefProvider. (RemoteActorRefProvider.scala: 128) в sun.reflect.NativeConstructorAccessorImpl.newInstance0 (собственный метод) в sun.reflect.NativeConstructorAccessorImpl.newInstance.nl_mpion.jpgDelegatingConstructorAccessorImpl.java:45) в java.lang.reflect.Constructor.newInstance (Constructor.java:423) в akka.actor.ReflectiveDynamicAccess $$ anonfun $ createInstanceFor $ 2.apply (ReflectiveDynamicAccess.scalautil at 32):$ .apply (Try.scala: 192) в akka.actor.ReflectiveDynamicAccess.createInstanceFor (ReflectiveDynamicAccess.scala: 27) в akka.actor.ReflectiveDynamicAccess $$ anonfun $ createInstanceFor $ 3.apply (ReflectiveDynamicAccessor).ReflectiveDynamicAccess $$ anonfun $ createInstanceFor $ 3.apply (ReflectiveDynamicAccess.scala: 38) в scala.util.Success.flatMap (Try.scala: 231) в akka.actor.ReflectiveDynamicAccess.createInstanceFor (ReflectiveDynamic 38)t akka.actor.ActorSystemImpl.liftedTree1 $ 1 (ActorSystem.scala: 620) в akka.actor.ActorSystemImpl. (ActorSystem.scala: 613) в akka.actor.ActorSystem $ .apply (ActorSystem.scala: 142) в акк..ActorSystem $ .apply (ActorSystem.scala: 119) в akka.actor.ActorSystem $ .create (ActorSystem.scala: 67) в akka.actor.ActorSystem.create (ActorSystem.scala) в com.akkademo.Main.main (Main.java:15)

1 Ответ

0 голосов
/ 01 января 2019

Вероятно, проблема вызвана использованием других вспомогательных версий akka-remoting и базового пакета akka-actor.

Установите для свойств akka.version и akka.remote одинаковое значение.Текущий выпуск 2.5.19.

...