首页 > 其他分享 >rabbitmq

rabbitmq

时间:2022-12-13 23:33:23浏览次数:111  
标签:void rabbitmq class context message public


一.1.   下载

下载地址:http://www.rabbitmq.com/download.html

2.   windows下安装

2.1. 安装Erlang

下载:​64_17.3.exe">​http://www.erlang.org/download/otp_win64_17.3.exe

安装:

rabbitmq_System

rabbitmq_Test_02

rabbitmq_System_03

rabbitmq_System_04

rabbitmq_spring_05

安装完成。

2.2. 安装RabbitMQ

rabbitmq_spring_06

rabbitmq_System_07

rabbitmq_System_08

安装完成。


rabbitmq_Test_09


启动、停止、重新安装等。

2.3. 启用管理工具


rabbitmq_Test_10

    1. 
    rabbitmq-plugins enable rabbitmq_management


    rabbitmq_Test_11


    1. 在浏览器中输入地址查看:​http://127.0.0.1:15672/

    rabbitmq_System_12



    3.   Linux下安装

    3.1. 安装Erlang

    3.1.1.   添加yum支持

    cd /usr/local/src/

    mkdir rabbitmq

    cd rabbitmq


    wget ​http://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm

    rpm -Uvh erlang-solutions-1.0-1.noarch.rpm


    rpm --import ​http://packages.erlang-solutions.com/rpm/erlang_solutions.asc


    sudo yum install erlang


    rabbitmq_spring_13

    3.2. 安装RabbitMQ

    上传rabbitmq-server-3.4.1-1.noarch.rpm文件到/usr/local/src/rabbitmq/

    安装:

    rpm -ivh rabbitmq-server-3.4.1-1.noarch.rpm


    3.2.1.   启动、停止

    service rabbitmq-server start

    service rabbitmq-server stop

    service rabbitmq-server restart

    3.2.2.   设置开机启动

    chkconfig rabbitmq-server on

    3.2.3.   设置配置文件

    cd /etc/rabbitmq

    cp /usr/share/doc/rabbitmq-server-3.4.1/rabbitmq.config.example /etc/rabbitmq/


    mv rabbitmq.config.example rabbitmq.config

    3.2.4.   开启用户远程访问

    vi /etc/rabbitmq/rabbitmq.config

    rabbitmq_spring_14

    注意要去掉后面的逗号。

    3.2.5.   开启web界面管理工具

    rabbitmq-plugins enable rabbitmq_management

    service rabbitmq-server restart

    3.2.6.   防火墙开放15672端口

    /sbin/iptables -I INPUT -p tcp --dport 15672 -j ACCEPT

    /etc/rc.d/init.d/iptables save

    4.   添加用户

    rabbitmq_Test_15

    4.1. 用户角色


    可登陆管理控制台,可查看所有的信息,并且可以对用户,策略(policy)进行操作。


    可登陆管理控制台,同时可以查看rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等)


    可登陆管理控制台, 同时可以对policy进行管理。但无法查看节点的相关信息(上图红框标识的部分)。


    仅可登陆管理控制台,无法看到节点信息,也无法对策略进行管理。


    无法登陆管理控制台,通常就是普通的生产者和消费者。

    4.2. 创建Virtual Hosts

    rabbitmq_Test_16



    设置权限:

    rabbitmq_Test_17

    rabbitmq_Test_18



    二.1.cmd启动rabbit.

    rabbitmq_System_19

    输入:rabbitmq-plugins enable rabbitmq_management


    2,设置虚拟主机

    1)双击,进去配置修改.

    rabbitmq_spring_20

    2)某个用户是这个虚拟主机

    rabbitmq_spring_20

    3.删除虚拟主机

    rabbitmq_spring_22

    三.spring-rabbitmq的集成

    spring-boot选择热部署和mq和web

    首先在服务器上安装rabbitmq的服务,用docker拉取即可,不再详细描述。

    直接来撸代码

    首先我们先添加rabbitmq的依赖

    <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-amqp</artifactId></dependency>

    在配置文件中添加必要的配置信息

    spring.rabbitmq.host=192.168.0.86spring.rabbitmq.port=5672spring.rabbitmq.username=adminspring.rabbitmq.password=123456

    好了,基本的配置就已经配置完毕了

    rabbitmq有六种模式

    rabbitmq_System_23


    我们逐个来看springboot是怎么实现的呢

    1.hello world

    创建service会有直接剔除即可,move

    rabbitmq_spring_24


    rabbitmq_spring_25



    我们先创建一个队列

    @Bean    public Queue Queue() {        return new

    然后我再创建一个生产者

    rabbitmq_spring_26

    @Controllerpublic class HelloSender {     @Autowired    private AmqpTemplate rabbitTemplate;     public void send() {        String context = "hello " + new Date();        System.out.println("Sender : " + context);        this.rabbitTemplate.convertAndSend("hello", context);    }}


    rabbitmq_System_27

    再创建一个消费者

    rabbitmq_spring_28

    @Component@RabbitListener(queues = "hello")public class HelloReceiver {    @RabbitHandler    public void

    rabbitmq_Test_29

    再写一个测试用例看看

    rabbitmq_Test_30

    @RunWith(SpringRunner.class)@SpringBootTestpublic class RabbitmqApplicationTests {        @Autowired        private HelloSender helloSender;         @Test        public void hello() throws


    rabbitmq_spring_31


    rabbitmq_System_32

    成功!

    2.工作模式(竞争)

    rabbitmq_System_33

    一个消息产生者,多个消息的消费者。竞争抢消息

    我们先创建一个队列

    @Bean    public Queue Queue2() {        return new

    再创建一个消息生产者

    rabbitmq_System_34

    @Controllerpublic class NeoSender {    @Autowired    private AmqpTemplate rabbitTemplate;     public void send(int i) {        String context = "spirng boot neo queue"+" ****** "+i;        System.out.println("Sender1 : " + context);        this.rabbitTemplate.convertAndSend("neo", context);    }}


    rabbitmq_spring_35

    再创建两个消息的消费者

    rabbitmq_System_36

    1 @Component 2 @RabbitListener(queues = "neo") 3 public class NeoReceiver1 { 4     @RabbitHandler 5     public void process(String neo) { 6         System.out.println("Receiver 1: " + neo); 7     } 8 } 9 10 11 12 @Component13 @RabbitListener(queues = "neo")14 public class NeoReceiver2 {15     @RabbitHandler16     public void process(String neo) {17         System.out.println("Receiver 2: " + neo);18     }19 20

    rabbitmq_Test_37

    我们写一个测试用例

    rabbitmq_System_38

    @Test    public void oneToMany() throws Exception {        for (int i=0;i<100;i++){           // Thread.sleep(10);


    rabbitmq_spring_39

    运行


    rabbitmq_System_40

    rabbitmq_spring_41

    可以看到消息均匀的被两个消费者消费了。

    通过这个例子我们可以看做高并发情况下的消息产生和消费,这会产生一个消息丢失的问题。万一客户端在处理消息的时候挂了,那这条消息就相当于被浪费了,针对这种情况,rabbitmq推出了消息ack机制,熟悉tcp三次握手的一定不会陌生。

    我们看看springboot是实现ack的

    很简单,在我们的配置类中,配置一个新的消费者,将原先的消费者先都去掉:

    rabbitmq_Test_42

    @Bean
    public
    SimpleMessageListenerContainer container = new

    container.setExposeListenerChannel(true);


    container.setAcknowledgeMode(AcknowledgeMode.MANUAL);//消息确认后才能删除
    container.setPrefetchCount(5);//每次处理5条消息
    container.setMessageListener(new

    public void onMessage(Message message, com.rabbitmq.client.Channel channel) throws
    byte[] body = message.getBody();
    System.out.println("消费端接收到消息 : " + new
    channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);

    return


    rabbitmq_spring_43


    但这里会有个问题,test模式下消息发送完毕系统就会直接shutdown,所以只能消费部分消息,不过等真正启动项目,这个问题就不存在了。

    3.发布订阅模式

    rabbitmq_Test_44

    生产者将消息不是直接发送到队列,而是发送到X交换机,然后由交换机发送给两个队列,两个消费者各自监听一个队列,来消费消息。

    这种方式实现同一个消息被多个消费者消费。工作模式是同一个消息只能有一个消费者。

    我们新建三个队列

    rabbitmq_spring_45

    @Bean    public Queue AMessage() {        return new Queue("fanout.A");    }     @Bean    public Queue BMessage() {        return new Queue("fanout.B");    }     @Bean    public Queue CMessage() {        return new


    rabbitmq_Test_46

    再新建一个交换机

    @Bean    FanoutExchange fanoutExchange() {        return new

    再把这些队列绑定到交换机上去

    rabbitmq_Test_47

    @Bean    Binding bindingExchangeA(Queue AMessage, FanoutExchange fanoutExchange) {        return BindingBuilder.bind(AMessage).to(fanoutExchange);    }     @Bean    Binding bindingExchangeB(Queue BMessage, FanoutExchange fanoutExchange) {        return BindingBuilder.bind(BMessage).to(fanoutExchange);    }     @Bean    Binding bindingExchangeC(Queue CMessage, FanoutExchange fanoutExchange) {        return


    rabbitmq_Test_48

    基本的配置完成后,再新建一个消息生产者

    rabbitmq_Test_48

    @Componentpublic class FanoutSender {    @Autowired    private AmqpTemplate rabbitTemplate;     public void send() {        String context = "hi, fanout msg ";        System.out.println("Sender : " + context);        this.rabbitTemplate.convertAndSend("fanoutExchange","", context);    }}

    rabbitmq_spring_50

    同样的,我们再新建三个消息消费者c

    rabbitmq_System_51

    1 @Component 2 @RabbitListener(queues = "fanout.A") 3 public class FanoutReceiveA { 4  5     @RabbitHandler 6     public void process(String message) { 7         System.out.println("fanout Receiver A  : " + message); 8     } 9 }10 11 @Component12 @RabbitListener(queues = "fanout.B")13 public class FanoutReceiverB {14     @RabbitHandler15     public void process(String message) {16         System.out.println("fanout Receiver B: " + message);17     }18 }19 20 @Component21 @RabbitListener(queues = "fanout.C")22 public class FanoutReceiverC {23     @RabbitHandler24     public void process(String message) {25         System.out.println("fanout Receiver C: " + message);26     }27

    rabbitmq_spring_52

    三个消费者分别监听3个队列的内容

    新建一个测试用例:

    rabbitmq_Test_53

    @RunWith(SpringRunner.class)@SpringBootTestpublic class FanoutTest {    @Autowired    private FanoutSender fanoutSender;     @Test    public void


    rabbitmq_spring_54

    rabbitmq_spring_55



    4:路由模式

    rabbitmq_Test_56

    需要将一个队列绑定到交换机上,要求该消息与一个特定的路由键完全匹配,这是一个完整的匹配。



    5.主题模式

    发送端不只按固定的routing key发送消息,而是按字符串匹配发送,接收端同样如此

    符号#匹配一个或多个词,符号*匹配不多不少一个词。


    rabbitmq_spring_57

    4/5两者模式很相似,我们放在一起演示


    新建两个队列

    rabbitmq_spring_58

    final static String message = "topic.A";    final static String messages = "topic.B";      @Bean    public Queue queueMessage() {        return new Queue(TopicRabbitConfig.message);    }     @Bean    public Queue queueMessages() {        return new

    rabbitmq_Test_59

    新建一个交换机

    @Bean    TopicExchange exchange() {        return new

    绑定队列到交换机上,路由模式,需要完整匹配topic.message,才能接受

    @Bean    Binding bindingExchangeMessage(Queue queueMessage, TopicExchange exchange) {        return

    topic模式,前缀匹配到topic.即可接受

    @Bean    Binding bindingExchangeMessages(Queue queueMessages, TopicExchange exchange) {        return

    我们新建三个消息生产者

    rabbitmq_Test_60

    @Componentpublic class TopicSend {    @Autowired    private AmqpTemplate rabbitTemplate;     public void send() {        String context = "hi, i am message all";        System.out.println("Sender : " + context);        this.rabbitTemplate.convertAndSend("topicExchange", "topic.1", context);    }     public void send1() {        String context = "hi, i am message 1";        System.out.println("Sender : " + context);        this.rabbitTemplate.convertAndSend("topicExchange", "topic.message", context);    }     public void send2() {        String context = "hi, i am messages 2";        System.out.println("Sender : " + context);        this.rabbitTemplate.convertAndSend("topicExchange", "topic.messages", context);    }}


    rabbitmq_Test_61

    send的key是topic.1  send1的key是topic.message,send2的key是topic.messages

    所以理论上send会被两个队列消费,1.2都应该只有一个队列消费

    我们再新建两个消费者

    rabbitmq_Test_62

    @Component@RabbitListener(queues = "topic.A")public class TopicReceiver {    @RabbitHandler    public void

    @Component@RabbitListener(queues = "topic.B")public class TopicReceiver2 { @RabbitHandler public void


    rabbitmq_System_63

    写三个测试用例

    rabbitmq_System_64

    @RunWith(SpringRunner.class)@SpringBootTestpublic class TopicTest {    @Autowired    private TopicSend sender;     @Test    public void topic() throws Exception {        sender.send();    }     @Test    public void topic1() throws Exception {        sender.send1();    }     @Test    public void topic2() throws

    rabbitmq_Test_65

    send的运行结果

    rabbitmq_System_66

    send1的运行结果

    rabbitmq_System_67

    send2的运行结果

    rabbitmq_System_68


    结果符合预期。 


    标签:void,rabbitmq,class,context,message,public
    From: https://blog.51cto.com/u_15765446/5935280

    相关文章

    • RabbitMQ学习
      第1章消息队列1.MQ的相关概念1.1什么是MQ​ MQ(messagequeue),消息队列,本质是个队列,遵循先入先出原则,只不过队列中存放的内容是message而已,还是一种跨进程的通信机......
    • 【Go系列】集成RabbitMQ和Micro框架
      packagemmicroimport("encoding/json""fmt""github.com/go-micro/plugins/v4/broker/rabbitmq""go-micro.dev/v4""go-micro.dev/v4/broker"......
    • java springboot+rabbitmq+websocket 订阅展示
      记录工作需要的依赖<!--fastjson坐标--><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId>......
    • SpringBoot整合RabbitMQ
      1、Maven依赖<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.0.RELEASE</vers......
    • rabbitmq
      importcom.rabbitmq.client.Channel;importcom.rabbitmq.client.Connection;importcom.rabbitmq.client.ConnectionFactory;importjava.io.IOException;importja......
    • centos安装rabbitMQ
      centOS7安装rabbitMQ 由于rabbitMQ是使用erlang语言编写的,所以安装rabbitMQ之前,需要先安装erlang环境。注意:erlang和rabbitMQ版本需要匹配否则会安装失败或启动失败......
    • SpringBoot+RabbitMQ实现消息订阅发送
      RabbitMQ安装(docker)拉取rabbitmq镜像文件#未指定版本,拉取最新版本root#dockerpullrabbitmq启动镜像root#dockerrun-d--hostnamemy-rabbit--na......
    • RabbitMQ指南之一:"Hello World!"
      为什么要使用MQ消息中间件?它解决了什么问题?关于为什么要使用消息中间件?消息中间件是如何做到同步变异步、流量削锋、应用解耦的?网上已经有很多说明,我这里就不再说明了,读者可......
    • RabbitMQ实战指南
      RbbitMQ作用:解耦冗余(存储)扩展性削峰可恢复性顺序保证缓冲异步通信RabbitMQ从最初就实现了一个特性:使用协议本身就可以对队列和交换器(Exchange)这样的资源进行配......
    • CentOS7安装RabbitMQ.
      安装erlang:由于rabbitmq是基于erlang语言开发的,所以必须先安装erlang。安装依赖:yum-yinstallgccglibc-develmakencurses-developenssl-develxmltoperlwgetgtk2-......