【问题标题】:Storm Supervisor can't find KafkaSpout classStorm Supervisor 找不到 KafkaSpout 类
【发布时间】:2019-02-16 06:50:13
【问题描述】:

我正在使用 Apache Storm 1.1.2、Apache Kafka 0.10、Zookeeper 和 Docker Compose 编写一个 dockerized Java 9 Spring 应用程序。

我的拓扑完全在我的 dockerized 服务内的本地集群上运行,但现在我将它移动到生产集群时出现了问题。

我为 Storm 集群创建提交拓扑的服务似乎工作正常,代码在 PostConstruct 中看起来大多像这样

KafkaSpoutConfig<String,String> spoutConf = 
KafkaSpoutConfig.builder("kafka:9092", "topic")
  .setProp(ConsumerConfig.GROUP_ID_CONFIG, "my-group-id")
  .setProp(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, MyDeserializer.class)
.build();

TopologyBuilder builder = new TopologyBuilder();
builder.setSpout("kafkaSpoutId", new KafkaSpout<String,String>(spoutConf));
builder.setBolt("boltId", new MyBolt()).shuffleGrouping("kafkaSpoutId");

Config conf = new Config();
conf.setNumWorkers(2);
conf.put(Config.STORM_ZOOKEEPER_SERVERS, List.of("zookeeper"));
conf.put(Config.STORM_ZOOKEEPER_PORT, 2181);

conf.put(Config.NIMBUS_SEEDS, List.of("nimbus"));
conf.put(Config.NIMBUS_THRIFT_PORT, 6627);

System.setProperty("storm.jar","/opt/app.jar");
StormSubmitter.submitTopology("topology-id", conf, builder.createTopology());

我的 docker compose 文件看起来像这样。

version: "2.1"

services:
  my-service:
  image: my-service
  mem_limit: 4G
  memswap_limit: 4G
  networks:
    - default
  environment:
    - SPRING_PROFILES_ACTIVE=local

nimbus:
  image: storm:1.1.2
  container_name: nimbus
  command: >
    storm nimbus
      -c storm.zookeeper.servers="[\"zookeeper\"]"
      -c nimbus.seeds="[\"nimbus\"]"
  networks:
    - default
  ports:
    - 6627:6627

supervisor:
  image: storm:1.1.2
  container_name: supervisor
  command: >
    storm supervisor
      -c storm.zookeeper.servers="[\"zookeeper\"]"
      -c nimbus.seeds="[\"nimbus\"]"
  networks:
    - default
  depends_on:
    - nimbus
  links:
    - nimbus
  restart: always
  ports:
    - 6700
    - 6701
    - 6702
    - 6703

ui:
  image: storm:1.1.2
  command: storm ui -c nimbus.seeds="[\"nimbus\"]"
  networks: 
    - default
  ports:
    - 8081:8080

networks:
  default:
    external:
      name: myNetwork

所有容器都已启动。在 UI 中,我可以看到在 post 构造中创建的拓扑,但没有正在处理 Kafka 消息,并且应该使用本地 Kafka 生产者来生成聚合的 Bolt 没有发布。

/logs/worker-artifact/topology-id****/6700/worker.log 的主管容器中,我可以看到重复的两个异常。

第一个(我认为更重要的)是ClassNotFoundException: org.apache.storm.kafka.spout.KafkaSpout

第二个例外是org.apache.storm.shade.org.jboss.netty.channel.ChannelException: Failed to bind to: 0.0.0.0/0.0.0.0:6700

更新

很遗憾,我无法发布整个 pom,但这是我的 Storm 依赖项

 <dependency>
        <groupId>org.apache.storm</groupId>
        <artifactId>storm-core</artifactId>
        <version>${storm.version}</version>
    </dependency>

    <dependency>
        <groupId>org.apache.storm</groupId>
        <artifactId>storm-kafka-client</artifactId>
        <version>${storm.version}</version>
    </dependency>

    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
    </dependency>

这是我的 spring-boot-maven-plugin。我虽然添加配置以使复制到我的容器的 jar 不可执行,但可以解决问题。当我检查容器中的 jar 时,它看起来包含依赖项的行,但也包含大量乱码

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
              <executable>false</executable>
            </configuration>
        </plugin>

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-resources-plugin</artifactId>
        </plugin>
    </plugins>
</build>

这是我的大部分 dockerfile

FROM ${docker.repository}/openjdk:9.0.1

EXPOSE 80 1099

WORKDIR /opt

ENTRYPOINT ["java", \
    "-Dinfo.serviceName=${project.artifactId}", \
    "-Dinfo.serviceVersion=${project.version}"]

CMD ["-jar", "app.jar"]

LABEL VERSION="${project.version}" DESCRIPTION="${project.description}"

COPY ${project.build.finalName}-exec.jar /opt/app.jar

【问题讨论】:

  • 请发布您的 pom。我猜你打包拓扑 jar 的方式有问题,因为运行时显然缺少 KafkaSpout 类。
  • 谢谢!刚加了。这也是我在想的,但我不知道另一种方法可以将我的胖罐子放入容器中,以便 Storm 引用我正在做的其他类的类
  • 我不熟悉 spring-boot-maven-plugin,但是通过示例,看起来您可能错过了重新打包目标 docs.spring.io/spring-boot/docs/2.0.4.RELEASE/maven-plugin/… 的执行。除此之外,尝试构建 jar 并使用 zip 工具打开它。您应该能够判断 org.apache.storm.kafka.spout.KafkaSpout 类是否在其中。

标签: java apache-kafka docker-compose apache-storm apache-storm-topology


【解决方案1】:

我想通了。问题是我正在形成一个不可执行的罐子,但不是一个真正的胖罐子。我在我的 pom 中添加了以下插件

<plugin>
  <artifactId>maven-assembly-plugin</artifactId>
  <configuration>
    <descriptorRefs>
      <descriptorRef>jar-with-dependencies</descriptorRef>
    </descriptorRefs>
  </configuration>
</plugin>
<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-compiler-plugin</artifactId>
  <configuration>
    <source>1.8</source>
    <target>1.8</target>
  </configuration>
</plugin>

接下来我将 System 属性更改为 System.setProperty("storm.jar", "/opt/storm.jar");

并将以下行添加到我的 Dockerfile

COPY ${project.build.finalName}-jar-with-dependencies.jar /opt/storm.jar

最后我会先运行 mvn comiple assembly:single 然后将项目 jar 与依赖项从 target/ 复制到 target/docker-ready 就像 从项目目录 cp target/project-jar-with-dependencies.jar target/docker-ready/ 最后运行 mvn verify docker:build

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-06-29
    • 2016-06-29
    • 1970-01-01
    • 2015-08-15
    • 2015-07-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多