栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

分布式消息队列RocketMq入门安装和使用教程

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

分布式消息队列RocketMq入门安装和使用教程

下载与安装:

提示:下面以Mac为例,windows用户可参考。

1. 进入官网 点击Getting Started

2. 找到下载入口

3. 下载rocketmq


这里推荐下载binary包。不推荐下载source包,还得需要自己再编译一遍。

4. 下载rocketmq dashboard

在rocket mq 的github readme里有dashboard的下载链接,是source包,
下载后,设置一下rocketmq.config.namesrvAddr值,然后再通过mvn打成jar包。

启动RocketMq和RockerMq Dashboard: 1.启动nameServer和Broker

Mac上启动nameServer的命令如下

nohup  ./bin/mqnamesrv &

Mac上启动Broker的命令如下

nohup ./bin/mqbroker -n localhost:9876 &

看nameServer和Broker是否启动成功, 输入Jps命令查看进程NameSrvStartUp和BrokerStartup是否存在即可。

2.启动rocketmq dashboard

启动dashboard的命令如下

java -jar xx-dashborad.jar
生产者消费者Demo:

在搭建好nameServer和Broker后,即搭建好了消息存储的平台,所以现在需要生产者生产消息,消费者消费消息。下面以IDEA展示。

1. 新建Maven工程,引入依赖
 
        
            org.apache.rocketmq
            rocketmq-client
            4.9.1
        
    
2. 生产者生产消息
import org.apache.rocketmq.client.exception.MQBrokerException;
import org.apache.rocketmq.client.exception.MQClientException;
import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.SendResult;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.remoting.common.RemotingHelper;
import org.apache.rocketmq.remoting.exception.RemotingException;

import java.io.UnsupportedEncodingException;

public class Producer {
    public static void main(String[] args) throws MQClientException, UnsupportedEncodingException, MQBrokerException, RemotingException, InterruptedException {
        // 实例化消息生产者Producer
        DefaultMQProducer producer = new DefaultMQProducer("Producer_ycx");
        // 设置NameServer的地址
        producer.setNamesrvAddr("localhost:9876");
        // 启动Producer实例
        producer.start();
        for (int i = 0; i < 10; i++) {
            // 创建消息,并指定Topic,Tag和消息体
            Message msg = new Message("TopicTest" ,
                    "TagC" ,
                    ("Hello ycx " + i).getBytes(RemotingHelper.DEFAULT_CHARSET) 
            );
            // 发送消息到一个Broker
            SendResult sendResult = producer.send(msg);
            // 通过sendResult返回消息是否成功送达
            System.out.printf("%s%n", sendResult);
        }
        // 如果不再发送消息,关闭Producer实例。
        producer.shutdown();
    }
}

3. 消费者消费消息
import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyContext;
import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus;
import org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently;
import org.apache.rocketmq.client.exception.MQClientException;
import org.apache.rocketmq.common.message.MessageExt;

import java.util.List;

public class Consumer {
    public static void main(String[] args) throws MQClientException {
        // 实例化消费者
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("Consumer_ycx");

        // 设置NameServer的地址
        consumer.setNamesrvAddr("localhost:9876");

        // 订阅一个或者多个Topic,以及Tag来过滤需要消费的消息
        consumer.subscribe("TopicTest", "*");
        // 注册回调实现类来处理从broker拉取回来的消息
        consumer.registerMessageListener(new MessageListenerConcurrently() {
            @Override
            public ConsumeConcurrentlyStatus consumeMessage(List msgs, ConsumeConcurrentlyContext context) {
                //System.out.printf("%s Receive New Messages: %s %n", Thread.currentThread().getName(), msgs);
                for (int i = 0; i 
                    System.out.println("Receive New Message: "+new String(msgs.get(i).getBody()));
                }
                // 标记该消息已经被成功消费
                return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
            }
        });
        // 启动消费者实例
        consumer.start();
        System.out.printf("Consumer Started.%n");
    }
}

更多的demo可参考官方文档

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/863363.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号