Spring Rocketmq 普通消息 RocketMQTemplate的使用 同步+异步

Spring Rocketmq 普通消息 RocketMQTemplate的使用


)

前言

我是使用Spring注解的形式以及RocketMQTemplate来实现消息中间件RocketMq,欢迎留言讨论

1、第一种 以同步的方法实现

    /**
     * 普通消息示例
     *
     * @param message 接收需要发送的消息
     * @return
     */
    @Override
    public String sendMessage(String message) {
        //创建队列 MessageQueue 队列不要设置太大,默认值为4
        rocketMQTemplate.getProducer().setDefaultTopicQueueNums(4);

        //官方解释:为具有给定有效负载的消息创建新的构建器。
        //获取一个MessageBUilder对象,只有一个参数 payload ,里面存储的是需要发送的消息
//        最后面接上的build()方法是将MessageBuilder对象转换为Message对象。
        Message info = MessageBuilder.withPayload(message + (i++)).build();

//        以同步模式发送消息。此方法仅在发送过程完全完成时返回。可靠的同步传输广泛应用于重要通知信息、短信通知、短信营销系统等场合。
//        警告:该方法具有内推机构。那是。内部实现将在声明失败之前重试DefaultMQProducer.getRetryTimesWhenSendFailed次数。因此,多个消息可能潜在地传递给代理。这取决于应用程序开发人员来解决潜在的重复问题。
//        发送消息的方法
        rocketMQTemplate.convertAndSend("MQ_TOPIC", info);

        return "success:" + message;
    }
//        发送消息的方法
        rocketMQTemplate.convertAndSend("MQ_TOPIC", info);

convertAndSend() 方法实现的是RocketMQTemplate中的syncSend()方法,都是以同步的方法实现消息的发送,但不建议使用syncSend() 方法,因为没有对参数进行了序列化,运行速度会慢很多。在这里插入图片描述

2、第二种 以异步方式实现

       /**
     * 普通消息示例
     * 异步
     *
     * @param message 接收需要发送的消息
     * @return
     */
    @Override
    public String sendMessage(String message) {
        //创建队列 MessageQueue 队列不要设置太大,默认值为4
        rocketMQTemplate.getProducer().setDefaultTopicQueueNums(4);

        //官方解释:为具有给定有效负载的消息创建新的构建器。
        //获取一个MessageBUilder对象,只有一个参数 payload ,里面存储的是需要发送的消息
//        最后面接上的build()方法是将MessageBuilder对象转换为Message对象。
        Message info = MessageBuilder.withPayload(message + (i++)).build();

//        发送消息的方法 双向异步消息 会产生回调
//        rocketMQTemplate.asyncSend("MQ_TOPIC", info, new SendCallback() {
//            @Override
//            public void onSuccess(SendResult sendResult) {
//                System.out.println("成功回调消息");
//                System.out.println(sendResult);
//            }
//
//            @Override
//            public void onException(Throwable e) {
//                System.out.println("回调发生异常了");
//                System.out.println(e);
//            }
//        });


//      单向异步消息  不会产生回调
        rocketMQTemplate.sendOneWay("MQ_TOPIC", info);
        return "success:" + message;
    }

同步的方式实现是通过rpc远程调用实现的,异步是在传递消息的时候加个中间件,也就是Broker Server,在启动rocketmq时,也需启动broker代理已实现异步的效果。

rocketmq官网由此进入

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤: 1. 创建 Spring Boot 项目 使用 Spring Initializr 创建一个 Spring Boot 项目,选择需要的依赖,包括 Spring Web、Spring Cloud Discovery、Dubbo Starter、Mybatis Plus Starter、RocketMQ Starter、Sentinel Starter、Seata Starter、MySQL Driver 等。 2. 配置 Nacos 注册中心和配置中心 在 application.properties 文件中添加以下配置: ``` spring.cloud.nacos.discovery.server-addr=localhost:8848 spring.cloud.nacos.config.server-addr=localhost:8848 spring.cloud.nacos.config.namespace= spring.cloud.nacos.config.group=DEFAULT_GROUP spring.cloud.nacos.config.prefix=${spring.application.name} spring.cloud.nacos.config.file-extension=properties ``` 其中,server-addr 为 Nacos 的地址,namespace 为命名空间,group 为配置组,prefix 为配置文件前缀,file-extension 为配置文件后缀。 3. 配置 Dubbo 服务提供者和消费者 在 application.properties 文件中添加以下配置: ``` # Dubbo Provider spring.dubbo.application.name=${spring.application.name} spring.dubbo.registry.address=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.scan=tech.chitosh.oceanus.service # Dubbo Consumer spring.dubbo.consumer.check=false spring.dubbo.consumer.registry=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.consumer.timeout=5000 ``` 其中,application.name 为应用名称,scan 为扫描的 Dubbo 服务接口包名,check 为是否启用 Dubbo 健康检查,timeout 为 Dubbo 超时时间。 4. 配置 Mybatis Plus 和 MySQL 在 application.properties 文件中添加以下配置: ``` # Mybatis Plus mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.configuration.map-underscore-to-camel-case=true mybatis-plus.configuration.cache-enabled=true # MySQL spring.datasource.url=jdbc:mysql://localhost:3306/oceanus?useUnicode=true&characterEncoding=utf8&useSSL=false&allowMultiQueries=true&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` 其中,mapper-locations 为 Mybatis Plus 的 Mapper.xml 文件路径,map-underscore-to-camel-case 为下划线转驼峰的配置,url 为 MySQL 的连接字符串,username 和 password 为数据库用户名和密码。 5. 配置 RocketMQ 在 application.properties 文件中添加以下配置: ``` # RocketMQ rocketmq.name-server=localhost:9876 rocketmq.producer.group=oceanus rocketmq.consumer.group=oceanus ``` 其中,name-server 为 RocketMQ 的地址,producer.group 为生产者组,consumer.group 为消费者组。 6. 配置 Sentinel 在 application.properties 文件中添加以下配置: ``` # Sentinel spring.cloud.sentinel.transport.dashboard=localhost:8080 spring.cloud.sentinel.transport.port=8719 spring.cloud.sentinel.datasource.ds.nacos.server-addr=localhost:8848 spring.cloud.sentinel.datasource.ds.nacos.data-id=${spring.cloud.nacos.config.prefix}-sentinel spring.cloud.sentinel.datasource.ds.nacos.group=SENTINEL_GROUP ``` 其中,transport.dashboard 为 Sentinel 控制台地址,transport.port 为 Sentinel 所用的端口,datasource.ds.nacos.server-addr 为 Nacos 的地址,data-id 为 Sentinel 数据源的名称,group 为 Sentinel 数据源所在的组。 7. 配置 Seata 在 application.properties 文件中添加以下配置: ``` # Seata spring.cloud.alibaba.seata.tx-service-group=my_test_tx_group spring.cloud.alibaba.seata.enable-auto-data-source-proxy=true spring.cloud.alibaba.seata.config.type=nacos spring.cloud.alibaba.seata.config.nacos.server-addr=localhost:8848 spring.cloud.alibaba.seata.config.nacos.namespace= spring.cloud.alibaba.seata.config.nacos.group=SEATA_GROUP ``` 其中,tx-service-group 为 Seata 分布式事务组名称,enable-auto-data-source-proxy 为是否启用 Seata 数据源代理,config.type 为 Seata 配置类型,config.nacos.server-addr 为 Nacos 的地址,config.nacos.namespace 为命名空间,config.nacos.group 为 Seata 配置所在的组。 8. 编写代码 按照业务需求编写 Dubbo 服务接口和实现、Mybatis Plus DAO 层、RocketMQ 生产者和消费者、Sentinel 熔断降级规则等代码。 以上就是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤,希望对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值