RabbitMQ---初识
1、概述
1.1 RabbitMQ 是 实现了 高级消息队列协议(AMQP) 的开源 消息代理软件,也称为 面向消息的中间件;
AMQP:Advanced Message Queuing Protocol,一个面向消息中间件的开放式标准应用层协议;
1.1 AMQP要求 消息的提供者 和 客户端接受者 的行为 要实现 对不同供应商 可以用相同的方式(SMTP、HTTP、FTP等)进行互相操作;
1.2 基本概念:
Broker:消息队列服务器的实体,负责接收 消息生产者的消息,然后 将消息发送至消息接受者或者其他的Broker;
Exchange:消息交换机,消息第一个到达的地方,消息通过它指定的路由规则,分发到不同的消息队列中;
Exchange的类型:
Direct交换机、Topic交换机、Fanout交换机
Queue:消息队列,消息通过发送和路由之后最终到达的地方,到达Queue的消息即进入逻辑上等待消费的状态,
Binding:绑定,把Exchange和Queue按照路由规则绑定起来,就是Exchange和Queue之间的虚拟连接;
Routing Key:路由关键字,Exchange根据这个关键字进行消息投递;
Virtual host:虚拟主机,对Broker的虚拟划分,将消费者、生产者、二者依赖的AMQP相关结构 进行隔离,一般都是为了安全考虑,比如:在一个Broker中设置多个虚拟主机,对不同用户进行权限的分离;
Connection:连接,代表生产者、消费者、Broker之间进行通信的物理网络;
Channel:消息通道,用于连接生产者、消费者的逻辑结构,在一个客户端的每个连接中,可建立多个Channel,每个Channel代表一个会话任务,通过Channel可以隔离同一个连接中不同交互内容;
Producer:消息生产者,制造消息并发送消息的程序;
Consumer:消息消费者,接收消息并处理消息的程序;
1.2 RabbitMQ用Erlang语言编写,其集群和故障转移是构建在开放电信平台框架上的;
1.3 RabbitMQ支持 消息的持久化(将数据写在磁盘上),消息队列持久化包括3个部分:
Exchange持久化、Queue持久化、消息持久化
RabbitMQ---初识的更多相关文章
- rabbitmq技术
		
Rabbitmq 初识rabbitmq RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是AMQP(高级消息队列协议)的标准实现.如果不熟悉AMQP,直接看Rabbi ...
 - rabbitmq技术的一些感悟(一)
		
Rabbitmq 初识rabbitmq RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是AMQP(高级消息队列协议)的标准实现.假设不熟悉AMQP,直接看Rabbi ...
 - RabbitMQ入门-初识RabbitMQ
		
初识RabbitMQ 要说RabbitMQ,我们不得不先说下AMQP.AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面 ...
 - 第一节 初识RabbitMQ
		
原文:第一节 初识RabbitMQ 版权声明:未经本人同意,不得转载该文章,谢谢 https://blog.csdn.net/phocus1/article/details/87280120 1.什么 ...
 - 初识RabbitMQ系列之一:简单介绍
		
一:RabbitMQ是什么? 众所周知,MQ是Message Queue(消息队列)的意思,RabbitMQ就是众多MQ框架其中的一款,开源实现了AMQP协议(官网:http://www.amqp. ...
 - 初识RabbitMQ,附RabbitMQ+PHP演示实例
		
RabbitMQ是一个在AMQP基础上实现的企业级消息系统.何谓消息系统,就是消息队列系统,消息队列是""消费-生产者模型""的一个典型的代表,一端往消息队列中 ...
 - 初识RabbitMQ系列之三:.net 如何使用RabbitMQ
		
话不多说,直接上代码! 一:搭建一个解决方案框架:RabbitMQ_Demo 其中包含4个部分: 1:RabbitMQ 公用类库项目 2:一个生产者控制台项目 3:两个消费者控制台项目 项目结构如图: ...
 - 初识RabbitMQ系列之二:下载安装
		
一:Erlang安装 因为RabbitMQ 是Erlang语言开发的,所以首先要装上Erlang的环境 1)下载Erlang 下载官网:http://www.erlang.org/downloa ...
 - 初识RabbitMQ
		
1.安装 rabbitmq官网:http://www.rabbitmq.com/ 下载地址:https://packagecloud.io/rabbitmq 下载rabbitmq-server 安装脚 ...
 - [RabbitMQ学习笔记] - 初识RabbitMQ
		
RabbitMQ是一个由erlang开发的AMQP的开源实现. 核心概念 Message 消息,消息是不具名的,它由消息头和消息体组成,消息体是不透明的,而消息头则由 一系列的可选属性组成,这些属性包 ...
 
随机推荐
- git post-receive
			
1. 将 www 目录设为 777 2. 用git 用户 mkdir 并 git init 3. cat id_rsa.pub >. authorkeys
 - .NET基础 (04)基础类型和语法
			
基础类型和语法1 .NET中所有内建类型的基类是什么2 System.Object中包含哪些方法,哪些是虚方法3 值类型和引用类型的区别4 简述装箱和拆箱原理5 C#中是否有全局变量6 struct和 ...
 - delphi将工程文件转成dll
			
1.点击[File]—>[New]—>[Other]菜单项,打开[New Items],选择[New]: 2.选择[Dll Wizard]选项卡,点击ok,DLL工程创建成功. 3.点击[ ...
 - [LeetCode 题解]: Permutations
			
Given a collection of numbers, return all possible permutations. For example,[1,2,3] have the follow ...
 - Replication--数据库镜像阻塞复制日志读取器的解决的办法
			
问题描述:在同一数据库上使用镜像和复制,为保证镜像切换后,复制还能继续,因此当镜像断开或暂停时,复制日志读取器会被阻塞直到日志被同步到镜像从服务器端(无论异步还是同步).日志状态显示:复制的事务正等待 ...
 - Replication--使用备份初始化订阅--推送订阅
			
1. 修改发布属性"许从备份文件初始化"置为TRUE2. 备份数据库并在订阅服务器上还原3. 创建订阅 -------------------------------------- ...
 - ubuntu 跑.net core 2.0
			
安装.net core参考地址:http://www.microsoft.com/net/core/preview#linuxubuntu 服务器版本 UBbuntu 16.04 执行命令 ...
 - asp.net core 2.0类库项目读取配置文件
			
1.首先在类库项目中添加 这3个库. 2.在类库项目中添加AppSetting.cs.代码如下: using Microsoft.Extensions.Configuration;using Syst ...
 - 小修改,让mvc的验证锦上添点花(2)
			
上一篇文章我们演示了通过对jquery.validate.unobtrusive.js做点小修改,如何给MVC的验证添点花 主要还是修改了onError与onSuccess中的这两个方法 这两个方法也 ...
 - SDOI2010粟粟的书架
			
题目传送:https://www.luogu.org/problemnew/show/P2468 这是一个二合一的题目,前50% \(n!=1\)的分数中,我们考虑用动态规划来做. 设\(sum[i] ...