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

这篇具有很好参考价值的文章主要介绍了rabbitmq基础教程(ui,java,springamqp)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

任务一

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

创建一个队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

这样创建两个队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

模拟发送数据

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

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

绑定队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式同理绑定queue2

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

查看结果:

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

数据隔离

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第一步:新添用户

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

所以只能看,不能操作。

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

用Java代码操作

官网:RabbitMQ Tutorials — RabbitMQ

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

用Spring AMQP操作

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第二步:编写代码

pom文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.cyl</groupId>
    <artifactId>test09</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>test09</name>
    <description>test09</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.6.13</spring-boot.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <dependency>
            <groupId>com.rabbitmq</groupId>
            <artifactId>amqp-client</artifactId>
            <version>5.13.0</version>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>${spring-boot.version}</version>
                <configuration>
                    <mainClass>org.cyl.test09.Test09Application</mainClass>
                    <skip>true</skip>
                </configuration>
                <executions>
                    <execution>
                        <id>repackage</id>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

配置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),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

Work模型

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第一步:创建一个队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第二步:编写代码

发送:

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),rabbitmq,分布式

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

Fanout交换机

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第一步:创建队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第三步:编写代码

发送端:

    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),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第一步:创建两个队列

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

第三步:编写代码

接收方:

   @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),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

声明交换机和队列1

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

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

声明交换机和队列2

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

消息转换器

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

rabbitmq基础教程(ui,java,springamqp),rabbitmq,分布式

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

好了,基础讲完。文章来源地址https://www.toymoban.com/news/detail-801081.html

到了这里,关于rabbitmq基础教程(ui,java,springamqp)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • HBase完全分布式配置(下)hbase篇 保姆级教程(近乎零基础跟着配也能配对)

    配置前也是要确保前面都配置正确,把多余的jdk都删掉(不会删看笔者第一篇文章) 上传不再赘述 解压: 改名: 环境变量: 应用: 要修改jdk和设置zookeeper外部使用 由于hbase对hdfs有依赖关系,则需要将hadoop下的core-site.xml和hdfs-site.xml复制到hbase中的conf目录下 zookeeper-hadoop-

    2024年04月17日
    浏览(39)
  • Rabbitmq----分布式场景下的应用

    如果单机模式忘记也可以看看这个快速回顾rabbitmq,在做学习 消息队列在使用过程中,面临着很多实际问题需要思考: 消息从发送,到消费者接收,会经理多个过程: 其中的每一步都可能导致消息丢失,常见的丢失原因包括: 发送时丢失: 生产者发送的消息未送达exchange 消

    2024年02月08日
    浏览(50)
  • 微服务技术栈SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式(五):分布式搜索 ES-下

    聚合(aggregations)可以实现对文档数据的统计、分析、运算。聚合常见的有三类: 桶(Bucket)聚合:用来对文档做分组 TermAggregation:按照文档字段值分组 Date Histogram:按照日期阶梯分组,例如一周为一组,或者一月为一组 度量(Metric)聚合:用以计算一些值,比如:最大值

    2024年03月26日
    浏览(65)
  • Python爬虫分布式架构 - Redis/RabbitMQ工作流程介绍

    在大规模数据采集和处理任务中,使用分布式架构可以提高效率和可扩展性。本文将介绍Python爬虫分布式架构中常用的消息队列工具Redis和RabbitMQ的工作流程,帮助你理解分布式爬虫的原理和应用。 为什么需要分布式架构? 在数据采集任务中,单机爬虫可能面临性能瓶颈和资

    2024年02月11日
    浏览(45)
  • 分布式消息队列:Kafka vs RabbitMQ vs ActiveMQ

    在现代分布式系统中,消息队列是一种常见的异步通信模式,它可以帮助系统处理高并发、高可用性以及容错等问题。在这篇文章中,我们将深入探讨三种流行的分布式消息队列:Apache Kafka、RabbitMQ和ActiveMQ。我们将讨论它们的核心概念、算法原理、特点以及使用场景。 随着

    2024年02月02日
    浏览(63)
  • 微服务学习:SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

    目录 一、高级篇 二、面试篇 ==============实用篇============== day05-Elasticsearch01 1.初识elasticsearch 1.4.安装es、kibana 1.4.1.部署单点es 1.4.2.部署kibana 1.4.3.安装IK分词器 1.4.4.总结 2.索引库操作 2.1.mapping映射属性 2.2.索引库的CRUD 2.2.1.创建索引库和映射 2.2.2.查询索引库 2.2.3.修改索引库 2.

    2024年02月02日
    浏览(59)
  • (黑马出品_07)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

    [此文档是在心向阳光的天域的博客加了一些有助于自己的知识体系,也欢迎大家关注这个大佬的博客](https://blog.csdn.net/sinat_38316216/category_12263516.html) [是这个视频](https://www.bilibili.com/video/BV1LQ4y127n4/?p=5spm_id_from=pageDrivervd_source=9beb0a2f0cec6f01c2433a881b54152c) 聚合 可以让我们极其方便

    2024年03月12日
    浏览(56)
  • 分布式搜索引擎(Elastic Search)+消息队列(RabbitMQ)部署(商城4)

    1、全文搜索 Elastic search可以用于实现全文搜索功能,例如商城中对商品搜索、搜索、分类搜索、订单搜索、客户搜索等。它支持复杂的查询语句、中文分词、近似搜索等功能,可以快速地搜索并返回匹配的结果。 2、日志分析 Elastic search可以用于实现实时日志分析,例

    2024年02月04日
    浏览(51)
  • RabbitMQ——解决分布式事务问题,RabbitMQ的重要作用之一!!!通过可靠生产和可靠消费来完美解决!

    分布式事务是指涉及多个独立的计算机系统(也称为节点或参与者)之间的事务处理。在分布式系统中,每个节点可能各自拥有自己的数据存储和事务管理机制。分布式事务的目标是保证在跨多个节点执行的一系列操作可以以一致和可靠的方式执行和提交,即使在面对故障或

    2024年04月23日
    浏览(48)
  • 【大数据】Hadoop-3.3.4完全分布式安装(包含VMware16和Ubuntu22的下载安装及配置)、搭建、配置教程,以及Hadoop基础简介

    注:本篇文章主要涉及到: HDFS (分布式文件系统)、 YARN (资源管理和调度框架)、以及 MapReduce (离线计算)。 以下就是本篇文章所采用的的架构 。 (1)HDFS架构简述 HDFS架构图 注:上述的master、slave1、slave2均是主机名(结点名),可以和本篇文章不一致,但下面所有涉

    2023年04月17日
    浏览(99)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包