1、下载依赖
rocketmq-spring-boot-starter的依赖包如果不能直接从中央仓库下载的,需要自己将rocketmq-spring安装到本地仓库
源码地址:https://github.com/apache/rocketmq-spring
进入源码目录,执行如下命令:mvn clean install -Dmaven.skip.test=true
执行完上述两步 依赖会自动加入本地的maven仓库
从github上下载rocketmq-spring-boot-starter的依赖,下载网址:https://github.com/apache/rocketmq-spring
下载后解压
进入cmd,将rocketmq-spring安装到本地仓库
mvn install -Dmaven.skip.test=true
2、创建maven父项目
父项目下新建生产者和消费者子项目,父项目pom
<?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>
<groupId>com.lian</groupId>
<artifactId>rockettest</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<parent>
<artifactId>spring-boot-starter-parent</artifactId>
<groupId>org.springframework.boot</groupId>
<version>2.0.0.RELEASE</version>
</parent>
<modules>
<module>springboot-rocketmq-producer</module>
</modules>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.7.0</version>
<configuration>
<target>1.8</target>
<source>1.8</source>
</configuration>
</plugin>
</plugins>
</build>
</project>
3、消息生产者
1、创建maven项目
<?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">
<parent>
<artifactId>rockettest</artifactId>
<groupId>com.lian</groupId>
<version>1.0-SNAPSHOT</version>
<!--<relativePath/>设定一个空值默认值为../pom.xml 表示将始终从父级仓库中获取,不从本地路径获取-->
<!--<relativePath/>-->
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>springboot-rocketmq-producer</artifactId>
<dependencies>
<!--springboot和rocketmq包,此包包含rocketmq-client和rocket-common包-->
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
</project>
2、编写主启动
package com.lian;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
3、配置application.properties
#注册到namesrv
rocketmq.name-server=8.131.84.120:9876
rocketmq.producer.group=springboot-rocketmq-producer
4、测试
package com.lian;
import org.apache.rocketmq.spring.core.RocketMQTemplate;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest(classes = MainApplication.class)
public class TestApplication {
@Autowired
RocketMQTemplate rocketMQTemplate;
@Test
public void run(){
rocketMQTemplate.convertAndSend("MyTopic","hello".getBytes());
}
}
控制台查看
4、消息消费者
1、添加依赖
<?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">
<parent>
<artifactId>rockettest</artifactId>
<groupId>com.lian</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>springboot-rocketmq-consumer</artifactId>
<dependencies>
<!--springboot和rocketmq包,此包包含rocketmq-client和rocket-common包-->
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
</project>
2、配置文件application.properties
#注册到namesrv
rocketmq.name-server=8.131.84.120:9876
rocketmq.consumer.group=springboot-rocketmq-consumer
3、监听器类
package com.lian.listener;
import lombok.extern.slf4j.Slf4j;
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.springframework.stereotype.Component;
@Slf4j
@Component
@RocketMQMessageListener(topic = "MyTopic",consumerGroup = "${rocketmq.consumer.group}")
public class Consumer implements RocketMQListener<String> {
@Override
public void onMessage(String message) {
log.info("Receive message:" + message);
}
}
4、主启动类
package com.lian;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
5、测试
消费端控制台收到消息