項目源碼:https://gitee.com/yearns/yearns-kafka
首先我們看下項目的基本結構:
KafakaConsumer.java主要爲消費者,監聽消息。
KafkaSender.java爲生產者,發送消息。
application.properties爲基本配置文件
KafaApplicationTests.java爲測試生產者發送消息。
運行KafkaApplication.java。
運行KafaApplicationTests.java。
效果如下:
我們看下pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.yearns</groupId>
<artifactId>yearns-kafka</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>yearns-kafka</name>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--kafka 支持-->
<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>
<version>1.3.5.RELEASE</version><!--$NO-MVN-MAN-VER$-->
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
需要注意的是: spring-boot-starter-parent
1.5.6.RELEASE和kafka版本的兼容。
我服務器上kafka的版本爲:kafka_2.11-2.2.0
生產者使用了KafkaTemplate包。
消費者使用了註解@KafkaListener。
使用方式參考官方文檔,本文不再贅述:https://docs.spring.io/spring-kafka/api/。