SpringBoot2.X統合RocketMQ4.X

プロデューサーコード開発

ステップ1:非常に一般的なSpringBootプロジェクトを作成します。

ステップ2:該当する依存を追加します。

< 依存> 
    < groupIdを> org.apache.rocketmq </ groupIdを> 
    < たartifactId > rocketmq-クライアント</ たartifactId > 
    < バージョン> 4.3.0 </ バージョン> 
</ 依存関係>

第三段階:ライトコード

PayProducerクラスを以下に示します。

パッケージnet.xdclass.xdclassmq.jms。

輸入org.apache.rocketmq.client.exception.MQClientException。
輸入org.apache.rocketmq.client.producer.DefaultMQProducer;
輸入org.springframework.stereotype.Component; 

@Component 
パブリック クラスPayProducer { 

    プライベート文字列producerGroup = "pay_group" 

    プライベート文字列nameServerAddr =「192.168.0.104:9876」

    プライベートDefaultMQProducerプロデューサー。

    パブリックPayProducer(){ 
        プロデューサー = 新しいDefaultMQProducer(producerGroup)。

        // 指定のネームサーバ地址、多个地址以。隔开
        // producer.setNamesrvAddr( "192.168.100.141:9876;192.168.100.142:9876;192.168.100.149:9876"); 

        producer.setNamesrvAddr(nameServerAddr); 
        スタート(); 
    } 

    公共DefaultMQProducer getProducer(){
         戻り 、この.producerを; 
    } 

    / ** 
     *使用前にオブジェクトのみ初期化後は、いったん呼び出さなければなりません
     * / 
    公共 のボイドスタート(){
         試み{
             この.producer.start(); 
        } キャッチ(MQClientException E){ 
            e.printStackTrace(); 
        } 
    } 
    
    / ** 
     *アプリケーションの一般的な文脈で、コンテキストリスナーを行うの使用を閉じます
     * /
    公共 のボイドシャットダウン(){
         この.producer.shutdown(); 
    } 
}

PayControllerクラスを以下に示します。

パッケージnet.xdclass.xdclassmq.controller。

輸入net.xdclass.xdclassmq.jms.PayProducer;
輸入org.apache.rocketmq.client.exception.MQBrokerException。
輸入org.apache.rocketmq.client.exception.MQClientException。
輸入org.apache.rocketmq.client.producer.SendResult;
輸入org.apache.rocketmq.common.message.Message;
輸入org.apache.rocketmq.remoting.exception.RemotingException。
輸入org.springframework.beans.factory.annotation.Autowired;
輸入org.springframework.web.bind.annotation.RequestMapping。
輸入org.springframework.web.bind.annotation.RestController; 

インポートjava.util.HashMapを; 

@RestController 
パブリック クラスPayController { 

    @Autowired 
    プライベートPayProducer payProducer。

    プライベート 静的な  最終文字列のトピック=「pay_test_topic」

    (@RequestMapping "/ API / V1 / pay_cb" パブリックオブジェクトコールバック(文字列テキスト)はスローInterruptedExceptionある、RemotingException、MQClientException、MQBrokerException { 
        メッセージメッセージ = 新しいメッセージ(トピック、 "多賀"( "ハローrocketmq =" + テキスト)。 GetBytesメソッド())。
        SendResult sendResult = payProducer.getProducer()(メッセージ)を送ります。 
        のSystem.out.println(sendResult)。
        返す 新しい HashMapを<> (); 
    } 
}

ステップ4:テスト

視覚的な管理の背景を介してメッセージを表示します

 

 

Messageオブジェクト

  • トピック:トピック名
  • タグ:フィルタリングのためのタグ
  • キー:一意のメッセージ、フィールドは、ビジネスの組み合わせであってもよい識別する
  • ボディ:メッセージ本文、バイト配列

注:ブローカが元にメッセージを送信し、このトピックかどうかを判断する必要があります。ローカル環境はトピック、トピックを作成するための自動化された生産環境の提案閉鎖を作成自動的に開くように推奨されたときにブローカーが開始しました。手動で、その後、メッセージを届ける場合は、プログラムによって自動的に作成され、トピックを作成する遅延があるだろうことをお勧めします。自動的にトピックを作成します。autoCreateTopicEnable =真の無効原因:一貫性のあるバージョンにクライアントとサーバーのバージョンを。

概念モデル:作成したときにキューに対応する複数の以下のトピックは、トピックは、Orderクラスのトピックとして、指定することができます。

よくある間違い

org.apache.rocketmq.remoting.exception.RemotingTooMuchRequestException:
sendDefaultImplコールのタイムアウト
原因:阿里云存在多网卡,rocketmq都会根据当前网卡选择一个IP使用,当你的机器有多块网卡时,很有可能会有问题。比如,我遇到的问题是我机器上有两个IP,一个公网IP,一个私网IP, 因此需要配置broker.conf 指定当前的公网ip, 然后重新启动broker 
新增配置:conf/broker.conf  (属性名称brokerIP1=broker所在的公网ip地址 )
新增这个配置:brokerIP1=120.76.62.13  

启动命令:nohup sh bin/mqbroker -n localhost:9876  -c ./conf/broker.conf &

常见错误二

MQClientException: No route info of this topic, TopicTest1
原因:Broker 禁止自动创建 Topic,且用户没有通过手工方式创建 此Topic, 或者broker和Nameserver网络不通
解决:
通过 sh bin/mqbroker -m  查看配置
autoCreateTopicEnable=true 则自动创建topic

Centos7关闭防火墙  systemctl stop firewalld

常见错误三

控制台查看不了数据,提示连接 10909错误

原因:Rocket默认开启了VIP通道,VIP通道端口为10911-2=10909

解决:阿里云安全组需要增加一个端口 10909

其他错误:

https://blog.csdn.net/qq_14853889/article/details/81053145
https://blog.csdn.net/wangmx1993328/article/details/81588217#%E5%BC%82%E5%B8%B8%E8%AF%B4%E6%98%8E
https://www.jianshu.com/p/bfd6d849f156
https://blog.csdn.net/wangmx1993328/article/details/81588217

 

开发消费者代码

接着上面的工程,直接上代码,PayConsumer 类如下所示:

package net.xdclass.xdclassmq.jms;

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.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.common.message.MessageExt;
import org.springframework.stereotype.Component;

import java.io.UnsupportedEncodingException;
import java.util.List;

@Component
public class PayConsumer {
    private DefaultMQPushConsumer consumer;

    private String CONSUMER_GROUP = "pay_consumer_group";
    private String NAME_SERVER = "192.168.0.104:9876";
    private String TOPIC = "pay_test_topic";

    public PayConsumer() throws MQClientException {

        consumer = new DefaultMQPushConsumer(CONSUMER_GROUP);
        consumer.setNamesrvAddr(this.NAME_SERVER);
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_LAST_OFFSET);

        consumer.subscribe(this.TOPIC, "*");

//        consumer.registerMessageListener((MessageListenerConcurrently) (msgs, context) -> {
//            try {
//                Message msg = msgs.get(0);
//                System.out.printf("%s Receive New Messages: %s %n", Thread.currentThread().getName(), new String(msgs.get(0).getBody()));
//                String topic = msg.getTopic();
//                String body = new String(msg.getBody(), "utf-8");
//                String tags = msg.getTags();
//                String keys = msg.getKeys();
//                System.out.println("topic=" + topic + ", tags=" + tags + ", keys=" + keys + ", msg=" + body);
//                return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
//            } catch (UnsupportedEncodingException e) {
//                e.printStackTrace();
//                return ConsumeConcurrentlyStatus.RECONSUME_LATER;
//            }
//        });

        consumer.registerMessageListener(new MessageListenerConcurrently() {
            @Override
            public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> msgs, ConsumeConcurrentlyContext context) {
                try {
                    Message msg = msgs.get(0);
                    System.out.printf("%s Receive New Messages: %s %n", Thread.currentThread().getName(), new String(msgs.get(0).getBody()));

                    String topic = msg.getTopic();
                    String body = new String(msg.getBody(), "utf-8");
                    String tags = msg.getTags();
                    String keys = msg.getKeys();
                    System.out.println("topic=" + topic + ", tags=" + tags + ", keys=" + keys + ", msg=" + body);

                    return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
                } catch (UnsupportedEncodingException e) {

                    e.printStackTrace();
                    return ConsumeConcurrentlyStatus.RECONSUME_LATER;
                }
            }
        });

        consumer.start();
        System.out.println("consumer start ...");
    }
}

注释掉的部分采用 Lambda 表达式写法,效果是一样的。

常见问题

1、Caused by: org.apache.rocketmq.remoting.exception.RemotingConnectException: connect to <172.17.42.1:10911> failed 

2、com.alibaba.rocketmq.client.exception.MQClientException: Send [1] times, still failed, cost [1647]ms, Topic: TopicTest1, BrokersSent: [broker-a, null, null]

3、org.apache.rocketmq.client.exception.MQClientException: Send [3] times, still failed, cost [497]ms, Topic: TopicTest, BrokersSent: [Book-Air.local, 	MacBook-Air.local, MacBook-Air.local]
解决:多网卡问题处理
	1、设置producer:  producer.setVipChannelEnabled(false);
	2、编辑ROCKETMQ 配置文件:broker.conf(下列ip为自己的ip)
		namesrvAddr = 192.168.0.101:9876
		brokerIP1 = 192.168.0.101

4、DESC: service not available now, maybe disk full, CL:
	解决:修改启动脚本runbroker.sh,在里面增加一句话即可:		
	JAVA_OPT="${JAVA_OPT} -Drocketmq.broker.diskSpaceWarningLevelRatio=0.98"
	(磁盘保护的百分比设置成98%,只有磁盘空间使用率达到98%时才拒绝接收producer消息)
	
常见问题处理
	https://blog.csdn.net/sqzhao/article/details/54834761
	https://blog.csdn.net/mayifan0/article/details/67633729
	https://blog.csdn.net/a906423355/article/details/78192828

 

おすすめ

転載: www.cnblogs.com/jwen1994/p/12319048.html