码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • RabbitMQ 入门系列:2、基础含义理解:链接、通道、队列、交换机


    系列目录

    RabbitMQ 入门系列:1、MQ的应用场景的选择与RabbitMQ安装。

    RabbitMQ 入门系列:2、基础含义:链接、通道、队列、交换机。

    RabbitMQ 入门系列:3、基础含义:持久化、排它性、自动删除、强制性、路由键。

    RabbitMQ 入门系列:4、基础编码:官方SDK使用:链接创建、单例改造、发送消息、接收消息。

    RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

    RabbitMQ 入门系列:6、保障消息:不丢失:发送方、Rabbit存储端、接收方。

    RabbitMQ 入门系列:7、保障消息:不重复消费:产生消息的唯一ID。

    RabbitMQ 入门系列:8、扩展内容:接收信息时:可否根据RoutingKey过滤监听信息,答案是不能。

    RabbitMQ 入门系列:9、扩展内容:死信队列:真不适合当延时队列。

    RabbitMQ 入门系列:10、扩展内容:延时队列:延时队列插件及其有限的适用场景。

    前言:

    本系列介绍RabbitMQ,介绍RabbitMQ的基础概念的含义。

    并扫清网络上的一些错误或容易误导人的内容,帮助网友快速正确理解并掌握RabbitMQ。 

    下面开始本篇内容相关介绍。

    1、上图管理中心图:

     

    从管理中心可以看到,主要有以下几个大菜单:

    复制代码
    1、Overview:概述,就是基础监控。
    
    2、Connections:链接
    
    3、Channels:通道

    4、Exchanges 交换机
    5、Queues:队列 6、Admin:管理
    复制代码

    除去概述和管理,剩下三个是理解RabbitMQ的重要指标。

    下面进行基本概念介绍,涉及的代码,下一篇再介绍:

    1、链接:

    比如用官方的SDK创建一个链接:

    复制代码
    using RabbitMQ.Client;
    
    var factory = new ConnectionFactory()
    {
        HostName = "127.0.0.1",
        UserName = "guest",
        Password = "guest",
        VirtualHost = "/"
    };
    
    var connection = factory.CreateConnection();
    复制代码

    即产生一个链接:

     

    对于这段代码,如果在一个Web应用程序中不断执行,在大并发请求下会产生大量的链接,这是不可取的。 

    如果再加上分布式部署,大量Web应用再加大量并发,链接资源就不够用了。

    因此,官网的建议,是用户应该把它做成单例,一个应用尽量使用1个链接。

    官方为了让多个线程共享一个链接,又不互相影响,做出了通道的概念。

    2、通道:

    为了减少链接数,降低资源开销,RabbitMQ设计了通道的概念。

    1个链接可以创建无数个通道,然后主要的编码,就是针对通道编码。

    复制代码
    using RabbitMQ.Client;
    using System.Text;
    using RabbitMQ.Client.Events;
    
    var factory = new ConnectionFactory()
    {
        HostName = "127.0.0.1",
        UserName = "guest",
        Password = "guest",
        VirtualHost = "/"
    };
    
    var connection = factory.CreateConnection();
    
    var channel = connection.CreateModel();
    复制代码

     

     

    当然,这样编码在Web应用程序是不可取的,应该把链接那一块的创建整成单例,下面示例中将忽略获取链接这一块。

    因此,后续编码都是在获取单例链接,创建通道,然后再进行一步操作。

    3、队列:创建队列,发送消息、监听队列,获取消息。

    这里先描述队列,交换机这种多出来的概念,放到后面再进行描述:

    队列,即数据存档和获取数据的地方。

    简单需求下,只需要给把信息发给队列,然后监听队列获取信息就完事了。

    发送消息:

    复制代码
    ...
    var channel = connection.CreateModel();
    
    channel.QueueDeclare("FirstQueue", false, false, false);//创建队列
    channel.BasicPublish("", "FirstQueue", false, null, Encoding.UTF8.GetBytes("这是要发送的内容"));
    channel.Close();
    复制代码

     

     监听队列,并获取信息:

    复制代码
    ...
    var channel = connection.CreateModel();
    
    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var message = Encoding.UTF8.GetString(ea.Body.ToArray());
        Console.WriteLine("收到默认消息 {0}", message);
    };
    string msg = channel.BasicConsume(queue: "FirstQueue",
                          autoAck: true,
                          consumer: consumer);
    复制代码

     

    对于以上的发送到监听,都不涉及到交换机,直接来,直接去即可。

    那么,交换机概念的引入,有什么作用呢?

    4、交换机:

    如果通道的出现,是为了降低链接数,那么交换机的出现,竟然不是为了降低队列数。

    示例说明:比如一开始创建了一个用户队列:User :用它发送存储用户的注册信息队列

    后面新增需求,发现User要实现很多个分支:

    按照常规模式,也能实现,创建多个队列,可以满足需求。

    但随着业务和模块分支越来越多,队列可能会太多,不便于管理和维护。 

    一开始,以为:通过交换机,引入路由(routekey)后,结构会变化成:

    后来,发现理解错了,特别是被网上的教程误导,发现队列是没有子队列或根据routekey过滤拿数据的功能的。

    路由真实的效果是:允许发送一次,Copy信息同时发散到多个多队:

     

    发送: (可以发送1条,同时到匹配路由的3个队列去)

    channel.BasicPublish("User", "#.user", false, null, Encoding.UTF8.GetBytes("这是要发送的内容"));

    交换机有好几种路由功能,这些先放到后面,放这里不便于入门理解。

    对交换机的功能,理解上面中提到的路由真实的效果那一句话即可。

    总结:

    本篇介绍RabbitMQ的基础概念的含义,有助于快速理解并掌握RabbitMQ。 

  • 相关阅读:
    认识启动函数,找到用户入口
    【C++】位图(海量数据处理)
    什么是乐观锁?一文教你使用Mybatis-Plus实现乐观锁以及分页查询,带图详解
    【从java到Go】搭建Go的Web框架Gin
    音视频从入门到精通——FFmpeg分离出PCM数据实战
    HTML5、CSS3面试题(二)
    Prometheus&Grafana + clickhouse监控配置
    20220629_MyBatis_数据库增删改查练习(三)
    HTML知识点
    SQL server查询08-20点的时间段时间
  • 原文地址:https://www.cnblogs.com/cyq1162/p/16602500.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号