java - maven打包后如何运行jar
问题描述
我是 Java 新手,我想用 Java 编写一个简单的 Kafka 消费者应用程序。
pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.zhihu</groupId>
<artifactId>kafka-consumer</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>kafkadev</name>
<url>http://maven.apache.org</url>
<repositories>
<repository>
<!-- Proper URL for Cloudera maven artifactory -->
<id>cloudera</id>
<url>https://repository.cloudera.com/artifactory/cloudera-repos/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>org.apache.kafka</groupId>
<artifactId>kafka-clients</artifactId>
<version>2.1.0</version>
<scope>compile</scope>
</dependency>
<!-- gson -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.8.2</version>
</dependency>
<dependency>
<groupId>org.elasticsearch</groupId>
<artifactId>elasticsearch</artifactId>
<version>5.6.12</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.7.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
java源代码:
package zhihu;
import java.util.Arrays;
import java.util.Base64;
import java.util.Properties;
import java.io.UnsupportedEncodingException;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import com.google.gson.Gson;
public class ZhihuCommentConsumer {
public static void main(String[] args) throws InterruptedException, UnsupportedEncodingException {
Properties properties = new Properties();
properties.put("bootstrap.servers", "device1:9092,device2:9092");
properties.put("kafka.topic", "zhihu_comment");
properties.put("group.id", "test");
runMainLoop(args, properties);
}
static void runMainLoop(String[] args, Properties properties) throws InterruptedException, UnsupportedEncodingException {
// Create Kafka producer
KafkaConsumer<String, String> consumer = new KafkaConsumer<String, String>(properties);
try {
consumer.subscribe(Arrays.asList(properties.getProperty("kafka.topic")));
System.out.println("Subscribed to topic " + properties.getProperty("kafka.topic"));
while (true)
{
ConsumerRecords<String, String> records = consumer.poll(100);
for (ConsumerRecord<String, String> record : records) {
System.out.printf("partition = %s, offset = %d, key = %s, value = %s\n", record.partition(), record.offset(), record.key(), record.value() );
}
}
}
finally {
consumer.close();
}
}
}
这是层次结构:
├── pom.xml
├── src
│ └── main
│ └── java
│ └── zhihu
│ └── ZhihuCommentConsumer.java
└── target
├── classes
│ └── zhihu
│ └── ZhihuCommentConsumer.class
问题是:
我运行mvn package
在目标目录中生成jar文件,然后执行java -cp target/kafka-consumer-1.0-SNAPSHOT.jar zhihu.ZhihuCommentConsumer
(我不确定这是否正确)。
但是,事实证明:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/kafka/clients/consumer/KafkaConsumer
at zhihu.ZhihuCommentConsumer.runMainLoop(ZhihuCommentConsumer.java:33)
at zhihu.ZhihuCommentConsumer.main(ZhihuCommentConsumer.java:27)
Caused by: java.lang.ClassNotFoundException: org.apache.kafka.clients.consumer.KafkaConsumer
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 2 more
我检查了 maven 存储库.m2
,已经下载了 kafka-client 包。我应该怎么做才能以正确的方式运行应用程序?
非常感谢,我将不胜感激。
解决方案
推荐阅读
- javascript - 仅通过单击表单提交表单,而不是使用 javascript 的 from 字段
- json - 如何从 dart 中的 Json 文件中读取对象并将其映射到变量?
- python-3.x - 如何用python在一个文件中存储多行?
- django - Django Allauth 防止电子邮件验证和密码重置电子邮件滥用/垃圾邮件
- javascript - 开玩笑测试nodejs控制器
- scala - 使用 scala 案例类创建 JSON 对象
- reactjs - 如何将表格导出为 CSV?
- java - 数组溢出检查
- android - 在匕首模块的上下文中,Kotlin 对象和类有什么区别
- sql - 在包含记录的现有表中,如何创建一个新的 datetime2(2) 列并使用基于另一列的值填充它?