rabbitmq基础教程(ui,java,springamqp)

概述:安装看我上篇文章Docker安装rabbitmq-CSDN博客

任务一

rabbitmq基础教程(ui,java,springamqp)_第1张图片

创建一个队列

rabbitmq基础教程(ui,java,springamqp)_第2张图片

这样创建两个队列

rabbitmq基础教程(ui,java,springamqp)_第3张图片

在amq.fanout交换机里面发送数据

模拟发送数据

rabbitmq基础教程(ui,java,springamqp)_第4张图片

发送消息,发现一下信息:

rabbitmq基础教程(ui,java,springamqp)_第5张图片

所以得出理论,消息发送是先到交换机,然后由交换机路由到消息队列

交换机是负责路由和转发消息的,并没有存储的功能。

绑定队列

rabbitmq基础教程(ui,java,springamqp)_第6张图片同理绑定queue2

rabbitmq基础教程(ui,java,springamqp)_第7张图片

这时,再在交换机中发消息

rabbitmq基础教程(ui,java,springamqp)_第8张图片

查看结果:

rabbitmq基础教程(ui,java,springamqp)_第9张图片

rabbitmq基础教程(ui,java,springamqp)_第10张图片

数据隔离

在rabbitmq中有虚拟主机的概念。

rabbitmq基础教程(ui,java,springamqp)_第11张图片

第一步:新添用户

rabbitmq基础教程(ui,java,springamqp)_第12张图片

添加成功后,发现没有虚拟主机,也就是说,我用这个用户登录后,是不可以操作上面的数据的。

又因为,我是超级管理员,所以我能看到这些

rabbitmq基础教程(ui,java,springamqp)_第13张图片

所以只能看,不能操作。

第二步:创立自己的虚拟主机

rabbitmq基础教程(ui,java,springamqp)_第14张图片

rabbitmq基础教程(ui,java,springamqp)_第15张图片

第三步:选自己的虚拟主机

rabbitmq基础教程(ui,java,springamqp)_第16张图片

选好后就只能看自己的了。

rabbitmq基础教程(ui,java,springamqp)_第17张图片

用Java代码操作

官网:RabbitMQ Tutorials — RabbitMQ

rabbitmq基础教程(ui,java,springamqp)_第18张图片

可以看到,官网上有案例,我们大多情况下用的是SpringAmqp,所以也就不讲那么多java简单调用的事情了。

用Spring AMQP操作

rabbitmq基础教程(ui,java,springamqp)_第19张图片

rabbitmq基础教程(ui,java,springamqp)_第20张图片

第一步:在控制台里面创建一个simple.queue队列

rabbitmq基础教程(ui,java,springamqp)_第21张图片

第二步:编写代码

pom文件



    4.0.0
    org.cyl
    test09
    0.0.1-SNAPSHOT
    test09
    test09
    
        1.8
        UTF-8
        UTF-8
        2.6.13
    
    
        
            org.springframework.boot
            spring-boot-starter-web
        

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

        
            org.springframework.boot
            spring-boot-starter-amqp
        
        
            com.rabbitmq
            amqp-client
            5.13.0
        
    
    
        
            
                org.springframework.boot
                spring-boot-dependencies
                ${spring-boot.version}
                pom
                import
            
        
    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                3.8.1
                
                    1.8
                    1.8
                    UTF-8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
                ${spring-boot.version}
                
                    org.cyl.test09.Test09Application
                    true
                
                
                    
                        repackage
                        
                            repackage
                        
                    
                
            
        
    


配置mq服务端消息

spring:
  rabbitmq:
    host: 192.168.56.10
    port: 5672
    virtual-host: /cmall
    username: cmall
    password: 123456

发送方:

package org.cyl.test09.demos;

import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class SendMessageService {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    public void testSimpleQueue(){
        String queueName="simple.queue";
        String message="hello,spring amqp!";
        rabbitTemplate.convertAndSend(queueName,message);
    }

    public void sendMessage(String exchange, String routingKey, Object message) {
        rabbitTemplate.convertAndSend(exchange, routingKey, message);
    }
}

接收方:

package org.cyl.test09.demos;

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Service;

@Service
public class ReceiveMessageService {

    @RabbitListener(queues = "simple.queue")
    public void receiveMessage(String message) {
        System.out.println("接收到的消息: " + message);
    }
}

controller类:

package org.cyl.test09.demos.controller;

import org.cyl.test09.demos.ReceiveMessageService;
import org.cyl.test09.demos.SendMessageService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {

    @Autowired
    SendMessageService sendMsgservice;

    @Autowired
    ReceiveMessageService receiveMsgService;

    @GetMapping("/send")
    public String send(){
        sendMsgservice.testSimpleQueue();
        return "ok";
    }

}

展示结果:

rabbitmq基础教程(ui,java,springamqp)_第22张图片

Work模型

rabbitmq基础教程(ui,java,springamqp)_第23张图片

rabbitmq基础教程(ui,java,springamqp)_第24张图片

第一步:创建一个队列

rabbitmq基础教程(ui,java,springamqp)_第25张图片

第二步:编写代码

发送:

package org.cyl.test09.demos;

import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class SendMessageService {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    public void testSimpleQueue() throws InterruptedException {
        String queueName="work.queue";

        for (int i=1;i<50;i++){
            String message="hello,spring amqp!_"+i;
            rabbitTemplate.convertAndSend(queueName,message);
            Thread.sleep(20);
        }

    }

    public void sendMessage(String exchange, String routingKey, Object message) {
        rabbitTemplate.convertAndSend(exchange, routingKey, message);
    }
}

接收:

package org.cyl.test09.demos;

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Service;

@Service
public class ReceiveMessageService {

    @RabbitListener(queues = "work.queue")
    public void receiveMessage1(String message) {
        System.out.println("消费者1接收到的消息: " + message);
    }
    @RabbitListener(queues = "work.queue")
    public void receiveMessage2(String message) {
        System.out.println("消费者2接收到的消息: " + message);
    }
}

结果展示:

rabbitmq基础教程(ui,java,springamqp)_第26张图片

消费者一和消费者二是轮询效果。

Fanout交换机

rabbitmq基础教程(ui,java,springamqp)_第27张图片

rabbitmq基础教程(ui,java,springamqp)_第28张图片

rabbitmq基础教程(ui,java,springamqp)_第29张图片

第一步:创建队列

rabbitmq基础教程(ui,java,springamqp)_第30张图片

第二步:创建交换机并绑定

rabbitmq基础教程(ui,java,springamqp)_第31张图片

rabbitmq基础教程(ui,java,springamqp)_第32张图片

第三步:编写代码

发送端:

    public void testFanout() {
        String exchangeName="cmall.fanout";
        String message="hello,spring everyone";
        rabbitTemplate.convertAndSend(exchangeName,null,message);
    }

接收端:

   @RabbitListener(queues = "fanout.queue1")
    public void receiveMessage3(String message) {
        System.out.println("消费者1接收到的消息: " + message);
    }
    @RabbitListener(queues = "fanout.queue2")
    public void receiveMessage4(String message) {
        System.out.println("消费者2接收到的消息: " + message);
    }

展示结果:

rabbitmq基础教程(ui,java,springamqp)_第33张图片

私发给不同的人:Direct交换机

rabbitmq基础教程(ui,java,springamqp)_第34张图片

rabbitmq基础教程(ui,java,springamqp)_第35张图片

第一步:创建两个队列

第二步:声明交换机并绑定

rabbitmq基础教程(ui,java,springamqp)_第36张图片

rabbitmq基础教程(ui,java,springamqp)_第37张图片

rabbitmq基础教程(ui,java,springamqp)_第38张图片

第三步:编写代码

接收方:

   @RabbitListener(queues = "direct.queue1")
    public void receiveMessage5(String message) {
        System.out.println("消费者1接收到的消息: " + message);
    }
    @RabbitListener(queues = "direct.queue2")
    public void receiveMessage6(String message) {
        System.out.println("消费者2接收到的消息: " + message);
    }

发送方:

    public void testDirect1() {
        String exchangeName="cmall.fanout";
        String message="hello,spring everyone";
        rabbitTemplate.convertAndSend(exchangeName,"red",message);
    }

    public void testDirect2() {
        String exchangeName="cmall.fanout";
        String message="hello,spring blue";
        rabbitTemplate.convertAndSend(exchangeName,"blue",message);
    }
    
    public void testDirect3() {
        String exchangeName="cmall.fanout";
        String message="hello,spring yellow";
        rabbitTemplate.convertAndSend(exchangeName,"yellow",message);
    }

Topic交换机

rabbitmq基础教程(ui,java,springamqp)_第39张图片

rabbitmq基础教程(ui,java,springamqp)_第40张图片

这个示例代码就懒得写了。

声明交换机和队列1

rabbitmq基础教程(ui,java,springamqp)_第41张图片

rabbitmq基础教程(ui,java,springamqp)_第42张图片

绑定队列到哪个交换机里面。

一般建立关系都是在消费者这边的。

声明交换机和队列2

rabbitmq基础教程(ui,java,springamqp)_第43张图片

基于注解式声明队列和交换机。

消息转换器

rabbitmq基础教程(ui,java,springamqp)_第44张图片

rabbitmq基础教程(ui,java,springamqp)_第45张图片

rabbitmq基础教程(ui,java,springamqp)_第46张图片

字节码可变,会有安全问题。

rabbitmq基础教程(ui,java,springamqp)_第47张图片

rabbitmq基础教程(ui,java,springamqp)_第48张图片

搞完以上东西,代码不用变,在发一次,即可为json。

好了,基础讲完。

你可能感兴趣的:(rabbitmq,分布式)