Java项目集成RocketMQ

文章目录

1.调整MQ的配置

1.进入bin目录
sh 复制代码
cd /usr/local/soft/rocketmq-all-4.8.0-bin-release/bin
2.关闭broker和namesrv
sh 复制代码
sh mqshutdown broker && sh mqshutdown namesrv
3.查看进程确认关闭
复制代码
ps -ef | grep NamesrvStartup && ps -ef | grep BrokerStartup
4.编辑配置文件broker.conf,配置brokerIP1
sh 复制代码
vim /usr/local/soft/rocketmq-all-4.8.0-bin-release/conf/broker.conf
sh 复制代码
# NameServer 地址(开端口)
namesrvAddr=

# brokerIP1 指定了 Broker 对外提供服务的 IP 地址
brokerIP1=

# listenPort 指定了 Broker 监听客户端连接的端口(开端口)
listenPort=10911

# 当这个选项设置为 true 时,如果客户端尝试向一个不存在的主题发送消息,Broker 会自动创建这个主题
autoCreateTopicEnable=true
5.开放端口10911
sh 复制代码
systemctl start firewalld && firewall-cmd --permanent --add-port=10911/tcp && firewall-cmd --reload && firewall-cmd --query-port=10911/tcp
6.重新启动
1.进入bin目录
sh 复制代码
cd /usr/local/soft/rocketmq-all-4.8.0-bin-release/bin
2.启动mqnamesrv和mqbroker
1.启动 NameServer 并将输出重定向到 mqnamesrv.log
sh 复制代码
nohup sh mqnamesrv > mqnamesrv.log 2>&1 &
2.启动 Broker 并将输出重定向到 mqbroker.log
sh 复制代码
nohup sh mqbroker -c ../conf/broker.conf > mqbroker.log 2>&1 &
3.实时监控 NameServer 的日志文件
sh 复制代码
tail -f mqnamesrv.log &
4.实时监控 Broker 的日志文件
sh 复制代码
tail -f mqbroker.log &
5.查看进程
sh 复制代码
ps -ef | grep NamesrvStartup && ps -ef | grep BrokerStartup

2.项目集成MQ

1.domain引入mq依赖
xml 复制代码
        <!-- rocketmq -->
        <dependency>
            <groupId>org.apache.rocketmq</groupId>
            <artifactId>rocketmq-spring-boot-starter</artifactId>
            <version>2.1.1</version>
        </dependency>
2.sun-club-application-mq 引入domain依赖,用于消费mq
xml 复制代码
        <!-- 引入domain层 -->
        <dependency>
            <groupId>com.sun.club</groupId>
            <artifactId>sun-club-domain</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
3.sun-club-starter 引入mq层
xml 复制代码
        <!-- 引入mq层 -->
        <dependency>
            <groupId>com.sun.club</groupId>
            <artifactId>sun-club-application-mq</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
4.application.yml 配置mq
yaml 复制代码
# mq配置
rocketmq:
  name-server:  # 作用是服务注册和发现,会自动发现broker
  producer:
    group: test-group
5.SubjectController.java
1.依赖注入 RocketMQTemplate
java 复制代码
    @Resource
    private RocketMQTemplate rocketMQTemplate;
2.编写controller,作为消息生产者
java 复制代码
    /**
     * 测试mq发送
     * @return
     */
    @GetMapping("/pushMessage")
    public Result<Boolean> pushMessage(@Param("id") int id) {
        rocketMQTemplate.convertAndSend("first-topic", "hello " + id);
        return Result.ok();
    }
6.TestConsumer.java 测试消费
java 复制代码
package com.sunxiansheng.subject.application.mq;

import com.sun.media.jfxmedia.logging.Logger;
import groovy.util.logging.Slf4j;
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

/**
 * Description:
 * @Author sun
 * @Create 2024/7/12 13:24
 * @Version 1.0
 */
@Component
// topic:主题,就是生产者那里指定的主题
// consumerGroup:消费组,在application.yml文件中配置的
// RocketMQListener<String>:这里的泛型就是消息的类型
@RocketMQMessageListener(topic = "first-topic", consumerGroup = "test-group")
@Slf4j
public class TestConsumer implements RocketMQListener<String> {

    private static final org.slf4j.Logger log = LoggerFactory.getLogger(TestConsumer.class);

    /**
     * 对消息进行消费
     * @param s
     */
    @Override
    public void onMessage(String s) {
        log.info("接受到消息了:{}", s);
    }

}
5.测试

3.点赞业务优化为MQ处理

1.SubjectLikedMessage.java 点赞消息实体
java 复制代码
package com.sunxiansheng.subject.domain.entity;

import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serializable;

/**
 * 题目点赞消息
 */
@Data
@Accessors(chain = true) // 支持链式调用
public class SubjectLikedMessage implements Serializable {

    /**
     * 题目id
     */
    private Long subjectId;

    /**
     * 点赞人id
     */
    private String likeUserId;

    /**
     * 点赞状态 1点赞 0不点赞
     */
    private Integer status;

}
2.sun-club-domain 同步点赞数据
1.SubjectLikedDomainService.java
java 复制代码
    /**
     * MQ同步点赞数据
     * @param subjectLikedBO
     */
    void syncLikedByMsg(SubjectLikedBO subjectLikedBO);
2.SubjectLikedDomainServiceImpl.java
java 复制代码
    @Override
    public void syncLikedByMsg(SubjectLikedBO subjectLikedBO) {
        SubjectLiked subjectLiked = new SubjectLiked();
        subjectLiked.setSubjectId(subjectLikedBO.getSubjectId());
        subjectLiked.setLikeUserId(subjectLikedBO.getLikeUserId());
        subjectLiked.setStatus(subjectLikedBO.getStatus());
        subjectLiked.setIsDeleted(IsDeleteFlagEnum.UN_DELETED.getCode());
        subjectLikedService.insert(subjectLiked);
    }
3.add方法逻辑修改
4.测试
相关推荐
huisheng_qaq19 小时前
【RocketMq源码篇-04】rocketmq的普通消息详解(broker存储位置,集群同步情况)
rocketmq·消息中间件·集群同步·普通消息·broker存储位置
小熊officer1 天前
RocketMQ简介
rocketmq
TracyCoder1235 天前
RocketMQ技术原理简单解析:从架构到核心流程
架构·wpf·rocketmq
zzhongcy5 天前
RocketMQ、Kafka 和 RabbitMQ 等中间件对比
kafka·rabbitmq·rocketmq
小股虫5 天前
RocketMQ消息可靠性实战:从发送到消费的全流程保障
rocketmq
u***u6856 天前
后端在消息队列中的可靠性保证
swiftui·ar·rocketmq
milanyangbo6 天前
从硬盘I/O到网络传输:Kafka与RocketMQ读写模型及零拷贝技术深度对比
java·网络·分布式·架构·kafka·rocketmq
写bug的小屁孩6 天前
主流消息队列(MQ)和技术选型
kafka·java-rocketmq·java-rabbitmq
Mr.朱鹏6 天前
RocketMQ可视化监控与管理
java·spring boot·spring·spring cloud·maven·intellij-idea·rocketmq
蜂蜜黄油呀土豆6 天前
RocketMQ 详解:从异步解耦到存储与消费全链路解析
消息队列·rocketmq·分布式账本·分布式系统·幂等设计