成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

SpringBoot RocketMQ 整合使用和監(jiān)控

Jacendfeng / 3396人閱讀

摘要:前提通過前面兩篇文章可以簡單的了解和安裝,今天就將和整合起來使用。然后我運(yùn)行之前的整合項目,查看監(jiān)控信息如下總結(jié)整篇文章講述了與整合和監(jiān)控平臺的搭建。

前提

通過前面兩篇文章可以簡單的了解 RocketMQ 和 安裝 RocketMQ ,今天就將 SpringBoot 和 RocketMQ 整合起來使用。

相關(guān)文章

1、SpringBoot Kafka 整合使用

2、SpringBoot RabbitMQ 整合使用

3、SpringBoot ActiveMQ 整合使用

4、Kafka 安裝及快速入門

5、SpringBoot RabbitMQ 整合進(jìn)階版

6、RocketMQ 初探

7、RocketMQ 安裝及快速入門

關(guān)注我

轉(zhuǎn)載請務(wù)必注明原創(chuàng)地址為:http://www.54tianzhisheng.cn/2018/02/07/SpringBoot-RocketMQ/

創(chuàng)建項目

在 IDEA 創(chuàng)建一個 SpringBoot 項目,項目結(jié)構(gòu)如下:

pom 文件

引入 RocketMQ 的一些相關(guān)依賴,最后的 pom 文件如下:



    4.0.0

    com.zhisheng
    rocketmq
    0.0.1-SNAPSHOT
    jar

    rocketmq
    Demo project for Spring Boot RocketMQ

    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.9.RELEASE
         
    

    
        UTF-8
        UTF-8
        1.8
    

    
        
            org.springframework.boot
            spring-boot-starter-web
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
            org.apache.rocketmq
            rocketmq-common
            4.2.0
        

        
            org.apache.rocketmq
            rocketmq-client
            4.2.0
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    
配置文件

application.properties 中如下:

# 消費者的組名
apache.rocketmq.consumer.PushConsumer=PushConsumer
# 生產(chǎn)者的組名
apache.rocketmq.producer.producerGroup=Producer
# NameServer地址
apache.rocketmq.namesrvAddr=localhost:9876
生產(chǎn)者
package com.zhisheng.rocketmq.client;

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.remoting.common.RemotingHelper;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.util.StopWatch;

import javax.annotation.PostConstruct;

/**
 * Created by zhisheng_tian on 2018/2/6
 */
@Component
public class RocketMQClient {
    /**
     * 生產(chǎn)者的組名
     */
    @Value("${apache.rocketmq.producer.producerGroup}")
    private String producerGroup;

    /**
     * NameServer 地址
     */
    @Value("${apache.rocketmq.namesrvAddr}")
    private String namesrvAddr;

    @PostConstruct
    public void defaultMQProducer() {
        //生產(chǎn)者的組名
        DefaultMQProducer producer = new DefaultMQProducer(producerGroup);
        //指定NameServer地址,多個地址以 ; 隔開
        producer.setNamesrvAddr(namesrvAddr);

        try {
            /**
             * Producer對象在使用之前必須要調(diào)用start初始化,初始化一次即可
             * 注意:切記不可以在每次發(fā)送消息時,都調(diào)用start方法
             */
            producer.start();

               //創(chuàng)建一個消息實例,包含 topic、tag 和 消息體
             //如下:topic 為 "TopicTest",tag 為 "push"
            Message message = new Message("TopicTest", "push", "發(fā)送消息----zhisheng-----".getBytes(RemotingHelper.DEFAULT_CHARSET));

            StopWatch stop = new StopWatch();
            stop.start();

            for (int i = 0; i < 10000; i++) {
                SendResult result = producer.send(message);
                System.out.println("發(fā)送響應(yīng):MsgId:" + result.getMsgId() + ",發(fā)送狀態(tài):" + result.getSendStatus());
            }
            stop.stop();
            System.out.println("----------------發(fā)送一萬條消息耗時:" + stop.getTotalTimeMillis());
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            producer.shutdown();
        }
    }
}
消費者
package com.zhisheng.rocketmq.server;

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus;
import org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;
import org.apache.rocketmq.remoting.common.RemotingHelper;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;

/**
 * Created by zhisheng_tian on 2018/2/6
 */
@Component
public class RocketMQServer {
    /**
     * 消費者的組名
     */
    @Value("${apache.rocketmq.consumer.PushConsumer}")
    private String consumerGroup;

    /**
     * NameServer 地址
     */
    @Value("${apache.rocketmq.namesrvAddr}")
    private String namesrvAddr;

    @PostConstruct
    public void defaultMQPushConsumer() {
        //消費者的組名
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer(consumerGroup);

        //指定NameServer地址,多個地址以 ; 隔開
        consumer.setNamesrvAddr(namesrvAddr);
        try {
            //訂閱PushTopic下Tag為push的消息
            consumer.subscribe("TopicTest", "push");

            //設(shè)置Consumer第一次啟動是從隊列頭部開始消費還是隊列尾部開始消費
            //如果非第一次啟動,那么按照上次消費的位置繼續(xù)消費
            consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);
            consumer.registerMessageListener((MessageListenerConcurrently) (list, context) -> {
                try {
                    for (MessageExt messageExt : list) {

                        System.out.println("messageExt: " + messageExt);//輸出消息內(nèi)容

                        String messageBody = new String(messageExt.getBody(), RemotingHelper.DEFAULT_CHARSET);

                        System.out.println("消費響應(yīng):msgId : " + messageExt.getMsgId() + ",  msgBody : " + messageBody);//輸出消息內(nèi)容
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                    return ConsumeConcurrentlyStatus.RECONSUME_LATER; //稍后再試
                }
                return ConsumeConcurrentlyStatus.CONSUME_SUCCESS; //消費成功
            });
            consumer.start();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
啟動類
package com.zhisheng.rocketmq;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class RocketmqApplication {

    public static void main(String[] args) {
        SpringApplication.run(RocketmqApplication.class, args);
    }
}
RocketMQ

代碼已經(jīng)都寫好了,接下來我們需要將與 RocketMQ 有關(guān)的啟動起來。

啟動 Name Server

在前面文章中已經(jīng)寫過怎么啟動,http://www.54tianzhisheng.cn/2018/02/06/RocketMQ-install/#%E5%90%AF%E5%8A%A8-NameServer

進(jìn)入到目錄 :

cd distribution/target/apache-rocketmq

啟動:

nohup sh bin/mqnamesrv &

tail -f ~/logs/rocketmqlogs/namesrv.log //通過日志查看是否啟動成功
啟動 Broker
nohup sh bin/mqbroker -n localhost:9876 &

tail -f ~/logs/rocketmqlogs/broker.log    //通過日志查看是否啟動成功

然后運(yùn)行啟動類,運(yùn)行效果如下:

監(jiān)控

RocketMQ有一個對其擴(kuò)展的開源項目 ocketmq-console ,如今也提交給了 Apache ,地址在:[https://github.com/apache/roc...]() ,官方也給出了其支持的功能的中文文檔:[https://github.com/apache/roc...]() , 那么該如何安裝?

Docker 安裝

1、獲取 Docker 鏡像

docker pull styletang/rocketmq-console-ng        

2、運(yùn)行,注意將你自己的 NameServer 地址替換下面的 127.0.0.1

docker run -e "JAVA_OPTS=-Drocketmq.namesrv.addr=127.0.0.1:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8080:8080 -t styletang/rocketmq-console-ng
非 Docker 安裝

我們 git clone 一份代碼到本地:

git clone https://github.com/apache/rocketmq-externals.git

cd rocketmq-externals/rocketmq-console/

需要 jdk 1.7 以上。 執(zhí)行以下命令:

mvn spring-boot:run

或者

mvn clean package -Dmaven.test.skip=true

java -jar target/rocketmq-console-ng-1.0.0.jar

注意:

1、如果你下載依賴緩慢,你可以重新設(shè)置 maven 的 mirror 為阿里云的鏡像


    
          alimaven
          aliyun maven
          http://maven.aliyun.com/nexus/content/groups/public/
          central        
    

2、如果你使用的 RocketMQ 版本小于 3.5.8,如果您使用 rocketmq < 3.5.8,請在啟動 rocketmq-console-ng 時添加 -Dcom.rocketmq.sendMessageWithVIPChannel = false(或者您可以在 ops 頁面中更改它)

3、更改 resource / application.properties 中的 rocketmq.config.namesrvAddr(或者可以在ops頁面中更改它)

錯誤解決方法

1、Docker 啟動項目報錯

org.apache.rocketmq.remoting.exception.RemotingConnectException: connect to failed

將 Docker 啟動命令改成如下以后:

docker run -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=127.0.0.1:9876 -Drocketmq.config.isVIPChannel=false" -p 8080:8080 -t styletang/rocketmq-console-ng

報錯信息改變了,新的報錯信息如下:

ERROR op=global_exception_handler_print_error

org.apache.rocketmq.console.exception.ServiceException: This date have"t data!

看到網(wǎng)上有人也遇到這個問題,他們都通過自己的方式解決了,但是方法我都試了,不適合我。不得不說,阿里,你能再用心點嗎?既然把 RocketMQ 捐給 Apache 了,這些文檔啥的都必須更新啊,不要還滯后著呢,不然少不了被吐槽!

搞了很久這種方法沒成功,暫時放棄!mmp

2、非 Docker 安裝,只好把源碼編譯打包了。

1) 注意需要修改如下圖中的配置:

rocketmq.config.namesrvAddr=localhost:9876        //注意替換你自己的ip

#如果你 rocketmq 版本小于 3.5.8 才需設(shè)置 `rocketmq.config.isVIPChannel` 為 false,默認(rèn)是 true, 這個可以在源碼中可以看到的
rocketmq.config.isVIPChannel=

2) 執(zhí)行以下命令:

mvn clean package -Dmaven.test.skip=true

編譯成功:

可以看到已經(jīng)打好了 jar 包:

運(yùn)行:

java -jar rocketmq-console-ng-1.0.0.jar

成功,不報錯了,開心?,訪問 http://localhost:8080/

整個監(jiān)控大概就是這些了。

然后我運(yùn)行之前的 SpringBoot 整合項目,查看監(jiān)控信息如下:

總結(jié)

整篇文章講述了 SpringBoot 與 RocketMQ 整合和 RocketMQ 監(jiān)控平臺的搭建。

參考文章

1、[http://www.ymq.io/2018/02/02/...]()

2、GitHub 官方 README

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/70963.html

相關(guān)文章

  • 寫這么多系列博客,怪不得找不到女朋友

    摘要:前提好幾周沒更新博客了,對不斷支持我博客的童鞋們說聲抱歉了。熟悉我的人都知道我寫博客的時間比較早,而且堅持的時間也比較久,一直到現(xiàn)在也是一直保持著更新狀態(tài)。 showImg(https://segmentfault.com/img/remote/1460000014076586?w=1920&h=1080); 前提 好幾周沒更新博客了,對不斷支持我博客的童鞋們說聲:抱歉了!。自己這段時...

    JerryWangSAP 評論0 收藏0
  • SpringBoot Admin 使用指南

    摘要:什么是是一個管理和監(jiān)控你的應(yīng)用程序的應(yīng)用程序。這些應(yīng)用程序通過通過注冊或者使用例如發(fā)現(xiàn)。剛才首頁的應(yīng)用列表后面有個紅色的,我們可以將注冊上去的應(yīng)用移除,但是只要你不把程序停掉,它立馬又會注冊上去。 showImg(http://ww3.sinaimg.cn/large/006tNc79ly1g5h6jqpgs9j30u00gwdhe.jpg); 什么是 SpringBoot Admin...

    FullStackDeveloper 評論0 收藏0
  • 使用Arthas 獲取Spring ApplicationContext還原問題現(xiàn)場

    摘要:背景最近來了個實習(xí)僧小弟,安排他實現(xiàn)對目標(biāo)網(wǎng)站連通性檢測的小功能簡單講就是將下邊的腳本換成代碼來實現(xiàn)百度平臺狀態(tài)不正常,請注意功能實現(xiàn)使用開始執(zhí)行定時任務(wù),檢測百度網(wǎng)站連通性請求百度成功,返回報文請求異常百度執(zhí)行檢測百度網(wǎng)站連通 背景 最近來了個實習(xí)僧小弟,安排他實現(xiàn)對目標(biāo)網(wǎng)站 連通性檢測的小功能,簡單講就是將下邊的shell 腳本換成Java 代碼來實現(xiàn) 1#!/bin/bash ...

    Amos 評論0 收藏0
  • SpringBoot Kafka 整合使用

    摘要:注意一定要親自自己安裝實踐,接下來我們將這兩個進(jìn)行整合。創(chuàng)建項目項目整體架構(gòu)使用創(chuàng)建項目,這個很簡單了,這里不做過多的講解。 showImg(http://ww4.sinaimg.cn/large/006tNc79gy1g5iatph25rj30u00gw0yj.jpg); 前提 假設(shè)你了解過 SpringBoot 和 Kafka。 1、SpringBoot 如果對 SpringBoo...

    BigTomato 評論0 收藏0
  • SpringBoot RabbitMQ 整合使用

    摘要:可以在地址看到如何使用講解下上面命令行表示控制臺端口號,可以在瀏覽器中通過控制臺來執(zhí)行的相關(guān)操作。同時從控制臺可以看到發(fā)送的速率多線程測試性能開了個線程,每個線程發(fā)送條消息。 showImg(http://ww2.sinaimg.cn/large/006tNc79ly1g5jjb62t88j30u00gwdi2.jpg); 前提 上次寫了篇文章,《SpringBoot Kafka 整合...

    yuanxin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<