【问题标题】:Error running Storm with Redis: java.lang.NoClassDefFoundError: Lredis/clients/jedis/Jedis使用 Redis 运行 Storm 时出错:java.lang.NoClassDefFoundError: Lredis/clients/jedis/Jedis
【发布时间】:2014-09-03 05:01:47
【问题描述】:

我的 Storm 类使用 Redis 队列来收集数据。

我尝试通过

运行我的 Storm jar
storm jar jar_file_name.jar Topology_name configuration_file

但我遇到了以下异常:

Exception in thread "main" java.lang.NoClassDefFoundError: Lredis/clients/jedis/Jedis;
    at java.lang.Class.getDeclaredFields0(Native Method)
    at java.lang.Class.privateGetDeclaredFields(Class.java:2397)
    at java.lang.Class.getDeclaredField(Class.java:1946)
    at java.io.ObjectStreamClass.getDeclaredSUID(ObjectStreamClass.java:1659)
    at java.io.ObjectStreamClass.access$700(ObjectStreamClass.java:72)
    at java.io.ObjectStreamClass$2.run(ObjectStreamClass.java:480)
    at java.io.ObjectStreamClass$2.run(ObjectStreamClass.java:468)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.io.ObjectStreamClass.<init>(ObjectStreamClass.java:468)
    at java.io.ObjectStreamClass.lookup(ObjectStreamClass.java:365)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1133)
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:347)
    at backtype.storm.utils.Utils.serialize(Utils.java:77)
    at backtype.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:111)
    at OutlierPredictor.main(OutlierPredictor.java:98)
 Caused by: java.lang.ClassNotFoundException: redis.clients.jedis.Jedis
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:358)

我已经编译使用

javac -classpath $HADOOP_CORE:$HBASE_CLASSPATH:/usr/local/hadoop-  2.2.0/redis_jar/commons-pool-1.5.5.jar:/usr/local/hadoop-2.2.0/redis_jar/jedis-2.1.0.jar:/usr/local/apache-storm-0.9.2-incubating/lib/storm-core-0.9.2-incubating.jar -d dir_name/ dir_name/Javafile.java 

从命令行。

我在单个节点设置中执行此操作。

出了什么问题?

【问题讨论】:

  • 我建议使用maven之类的项目管理工具来关心cp、编译和uberjar。

标签: java linux hadoop redis apache-storm


【解决方案1】:

您需要将所有代码和依赖项打包到一个 jar 中。

请参阅Storm tutorial,拓扑部分,

运行拓扑很简单。首先,你打包你所有的 代码和依赖项放到一个 jar 中。然后,您运行类似的命令 以下:

storm jar all-my-code.jar backtype.storm.MyTopology arg1 arg2

您可能必须使用一些打包工具,例如 OneJAR、JarJar 或 ANT,并创建一个包含所有文件和依赖项的 jar。请参考这些 SO 帖子

  1. Merging Multiple Jars in to a Single Jar
  2. Easiest way to merge a release into one JAR file

【讨论】:

    【解决方案2】:

    1)在依赖中添加jedis

    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>2.9.0</version>
    </dependency>
    

    2)使用组装插件将所有依赖打包到一个jar文件中

       <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.6</version>
            <configuration>
                <manifest>
                    <addClasspath>true</addClasspath>
                    <mainClass>your main class</mainClass>
                </manifest>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>your main class</mainClass>
                    </manifest>
                </archive>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    

    3) 忽略包中的storm-core

    <dependency>
        <groupId>org.apache.storm</groupId>
        <artifactId>storm-core</artifactId>
        <version>1.1.1</version>
        <scope>provided</scope>
    </dependency>
    

    【讨论】:

    • 请使用前面说的Maven依赖或者使用github仓库提供的Jedis jar
    【解决方案3】:

    谢谢约翰的回答。

    但我找到了另一个解决方案。

    我的 $STORM_HOME/lib/ 中没有包含 jedis-2.1.0.jar、commons-pool-1.5.5.jar

    注意:这两个文件在 $REDIS_CORE 中。

    【讨论】:

    • 我会说将 jedis 之类的其他 jar 放入 $STORM_HOME/lib/ 有点像 hack,不是正确的方法 :)
    【解决方案4】:

    我们使用 Jedis Configuration 时需要 JedisPoolConfig。在 Spring Boot 2.0 中,spring-boot-starter-data-redis 默认赋予 Lettuce 依赖,而不是 Jedis。要使用 Jedis 配置,请排除 Lettuce 并添加 Jedis,如下所示。

        <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
      <exclusions>
        <exclusion>
         <groupId>io.lettuce</groupId>
         <artifactId>lettuce-core</artifactId>
        </exclusion>
      </exclusions>            
    </dependency>        
    <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
    </dependency>
    

    【讨论】:

      猜你喜欢
      • 2018-12-22
      • 2022-10-01
      • 2017-03-30
      • 2015-10-13
      • 2016-12-10
      • 2018-11-04
      • 2016-10-18
      • 2017-07-04
      • 2014-12-11
      相关资源
      最近更新 更多