RabbitMQ基础篇
介绍
RabbitMQ 是一个消息中间件:它接收并转发消息。您可以把它想象为一个邮局:当您把需要寄出的邮件投递到邮箱,邮差最终会把邮件送给您的收件人。在这个比喻中,RabbitMQ 就是一个邮箱,也可以理解成邮局和邮递员。
RabbitMQ 和邮局的主要区别在于它不处理纸张,而是接收、存储和转发二进制数据块 - 消息。
RabbitMQ 和消息传递通常使用一些术语。
生产 的意思无非就是发送。发送消息的程序就是一个 生产者:
队列 就是 RabbitMQ 内部“邮箱”的名称。虽然消息流经 RabbitMQ 和您的应用程序,但它们只能存储在 队列 中。队列 只受主机的内存和磁盘的限制,它本质上就是一个很大的消息缓冲区。多个 生产者 可以发送消息到一个队列,并且多个 消费者 可以尝试从一个 队列 接收数据。这就是我们代表队列的方式:
消费 与接收有相似的含义,等待接收消息的程序就是一个 消费者:
注意:生产者、消费者和中间件不是必须部署在同一主机上,实际上在大多数应用程序中它们也不是这样的。
"Hello World"
使用 .NET / C#Client
在教程的这一部分,我们将用 C# 编写两个程序:一个发送单条消息的生产者,以及接收消息并将其打印出来的消费者。我们将忽略 .NET 客户端 API 中的一些细节,专注于更简单的开始。这是一个消息传递的“Hello World”。
在下图中,P
是我们的生产者,C
是我们的消费者。中间的盒子是队列 - RabbitMQ 代表消费者保存的消息缓冲区。
.NET 客户端库
RabbitMQ 支持多种协议,本教程使用
AMQP 0-9-1
,它是一种开放的、通用的消息传递协议。RabbitMQ 提供了一些针对不同 语言环境的客户端,我们将使用 RabbitMQ 提供的 .NET 客户端。客户端支持 .NET Core 以及 .NET Framework 4.5.1+。本教程将使用 .NET Core,因此您需要确保客户端已 安装 并且路径添加到
PATH
系统变量。您也可以使用 .NET Framework 来完成本教程,但设置步骤会有所不同。
RabbitMQ .NET 客户端 5.0 及更高版本通过 nuget 发布。
本教程假定您在 Windows 上使用 PowerShell。在 MacOS 和 Linux 上,几乎所有 shell 也都可以正常工作。
下载和安装RabbitMQ
1、RabbitMQ需要安装64位支持的Erlang for Windows版本。有一个用于Erlang的Windows安装程序。重要提示:必须使用管理帐户运行Erlang安装程序,否则RabbitMQ安装程序所需的注册表项将不存在。
然后,运行RabbitMQ安装程序rabbitmq-server-3.7.9.exe。它将RabbitMQ安装为Windows服务,并使用默认配置启动它。
RabbitMQ下载地址:http://www.rabbitmq.com/download.html
Erlang for Windows下载地址:http://www.erlang.org/downloads
2、使用管理运行otp_win64_21.1.exe安装程序
使用系统默认即可,直接点击Next。选择安装路径后直接Next:
等待安装完成即可。
3、安装rabbitmq-server-3.7.9.exe,直接Next:
选择安装路径,然后Next,等待安装完成即可:
安装完成后检查服务中是否存在RabbitMQ的服务,RabbitMQ安装后默认为windows服务:
4、安装可视化管理插件,使用cmd定位到你的安装目下,命令如下:
rabbitmq-plugins enable rabbitmq_management
出现如下提示后在浏览器中访问:http://localhost:15672/,这里暂时无法登陆,下面创建创建用户账号后才可登录
5、创建用户,密码,绑定角色
1、查看已有用户及用户的角色:
rabbitmqctl.bat list_users
2、创建用户:
rabbitmqctl add_user 用户名 密码
在次查看用户列表,会多出刚新建的admin用户
3、设置用户账号权限,以刚创建的用户账号admin为例设置为超级管理员。 命令如下:
rabbitmqctl set_user_tags admin administrator
查看用户列表 可以看出多了管理员权限,访问:http://localhost:15672/ 使用刚才创建的用户账号即可登录。
其他相关命令如下:
//设置用户权限
rabbitmqctl set_permissions -p VHostPath User ConfP WriteP ReadP //查看(指定hostpath)所有用户的权限信息
rabbitmqctl list_permissions [-p VHostPath] //查看指定用户的权限信息
rabbitmqctl list_user_permissions User // 清除用户的权限信息
rabbitmqctl clear_permissions [-p VHostPath] User //删除用户
rabbitmqctl delete_user Username //修改用户密码
rabbitmqctl change_password 用户名 新密码
基础使用
参考园里博文:https://www.cnblogs.com/stulzq/p/7551819.html
报错信息收集
1、报错信息:None of the specified endpoints were reachable,该错误是使用的用户账号没有相应Virtual Hosts权限。登录RabbitMQ查看用户列表 没有权限访问
解决方案:点击列表中的admin 进入如下图所所示界面,设置权限保持默认即可。检查Tags是否是administrator
RabbitMQ基础篇的更多相关文章
- 分布式系统消息中间件——RabbitMQ的使用基础篇
分布式系统消息中间件——RabbitMQ的使用基础篇
- RabbitMQ基础教程之基本使用篇
RabbitMQ基础教程之基本使用篇 最近因为工作原因使用到RabbitMQ,之前也接触过其他的mq消息中间件,从实际使用感觉来看,却不太一样,正好趁着周末,可以好好看一下RabbitMQ的相关知识点 ...
- RabbitMQ基础教程之Spring&JavaConfig使用篇
RabbitMQ基础教程之Spring使用篇 相关博文,推荐查看: RabbitMq基础教程之安装与测试 RabbitMq基础教程之基本概念 RabbitMQ基础教程之基本使用篇 RabbitMQ基础 ...
- RabbitMQ基础教程之使用进阶篇
RabbitMQ基础教程之使用进阶篇 相关博文,推荐查看: RabbitMq基础教程之安装与测试 RabbitMq基础教程之基本概念 RabbitMQ基础教程之基本使用篇 I. 背景 前一篇基本使用篇 ...
- RabbitMQ基础知识
RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...
- 转:RabbitMQ基础知识
RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...
- RabbitMq基础教程之基本概念
RabbitMq基础教程之基本概念 RabbitMQ是一个消息队列,和Kafka以及阿里的ActiveMQ从属性来讲,干的都是一回事.消息队列的主要目的实现消息的生产者和消费者之间的解耦,支持多应用之 ...
- RabbitMQ基础知识(转载)
RabbitMQ基础知识(转载) 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需 ...
- 消息中间件 RabbitMQ 入门篇
消息中间件 RabbitMQ 入门篇 五月君 K8S中文社区 今天 作者:五月君,来源:Nodejs技术栈 从不浪费时间的人,没有工夫抱怨时间不够.—— 杰弗逊 RabbitMQ 是一套开源(MP ...
随机推荐
- Java jdbc链接 mySQL 写的crud
1.JDBC(Java Data Base Connectivity java数据库连接)概念: 是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编 ...
- 进阶系列(11)—— C#多线程
一.多线程的相关概念 1.进程:是操作系统结构的基础:是一个正在执行的程序:计算机中正在运行的程序实例:可以分配给处理器并由处理器执行的一个实体:由单一顺序的执行显示,一个当前状态和一组相关的系统资源 ...
- 第二篇——VC++简单随机四则运算
目标:编写最简单的四则运算,类似A+B=C: 想法:建立一个Win32控制台应用程序,A和B用随机数表示,运算符号用0~3的数字对应,然后计算并输出即可: 具体过程: 利用函数rand(),返回一个0 ...
- 软工1816 · Beta冲刺(2/7)
团队信息 队名:爸爸饿了 组长博客:here 作业博客:here 组员情况 组员1(组长):王彬 过去两天完成了哪些任务 完成考试 确定历史记录页面与排行榜页面的前端页面风格 接下来的计划 & ...
- javascript修改div大小遮挡页面渲染问题
页面中引入了其他js文件,浏览器窗口改变,页面没有跟随渲染问题.最后找到原因是因为这个js方法少了最后一行: "right": RightBox_w. window.onresiz ...
- Java 线程间通讯
/* 线程间通讯: 多个线程在处理同一资源,但是任务却不同. */ package com.cwcec.test; class Input implements Runnable { Resource ...
- 解决在Mac上用pyenv安装python3失败的问题
背景 前段时间在本地Mac系统上要跑一个python3写的压测脚本. Mac默认安装的是python2, 而且很多软件依赖的也是python2. 为了不影响现有系统其它软件, 当时安装了pyenv来实 ...
- Linux基础五(系统管理)
Linux 系统管理 1. 进程管理 1.1 进程管理简介 进程的简介: 一个程序在运行的时候会占用系统的资源,即系统分配资源给某个程序使用,进程就是正在运行中的某个程序或者命令.进程又可以细分为线程 ...
- js ajax 1
var xmlHttpReq = null; //声明一个空对象用来装入XMLHttpRequest if (window.ActiveXObject){//IE5 IE6是以ActiveXObjec ...
- mongodb 下载安装 转
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型.M ...