RabbitMQ的使用(一)- RabbitMQ服务安装
RabbitMQ的使用(一)- RabbitMQ服务安装
作者:markjiang7m2
原文地址:https://www.cnblogs.com/markjiang7m2/p/12769627.html
官网地址:http://letyouknow.net
RabbitMQ,消息队列的一个中间件,这里不打算展开介绍了。此文意在记录工作中使用RabbitMQ时的过程及一些心得,大神可忽略。如有表述有误,各路大神可在留言区进行指正,不胜感谢。
Windows系统中安装RabbitMQ服务
安装Erlang运行环境
RabbitMQ是采用Erlang实现的,所以需要安装Erlang的运行环境。
安装Erlang OTP,官网下载https://www.erlang.org/downloads,版本自行选择,我这里用的是otp_win64_22.3.exe,下载完可执行文件双击运行安装即可,这里不展开。
安装RabbitMQ
官网下载https://www.rabbitmq.com/download.html,版本自行选择,我这里用的是rabbitmq-server-3.8.3.exe,也是直接安装即可,这里不展开
启动RabbitMQ服务
打开cmd命令框,切换至C:\Program Files\RabbitMQ Server\rabbitmq_server-3.8.3\sbin目录下,输入rabbitmqctl status查看状态,如果未启动,则可以通过rabbitmq-service进行启动,或者到Windows服务启动
rabbitmq-service命令如下,按需执行:
# 安装RabbitMQ服务
rabbitmq-service install
# 启动RabbitMQ服务
rabbitmq-service start
# 停止RabbitMQ服务
rabbitmq-service stop
# 删除RabbitMQ服务
rabbitmq-service remove
启用RabbitMQ管理插件
#cmd命令
rabbitmq-plugins.bat enable rabbitmq_management
然后在浏览器访问地址http://localhost:15672/,输入默认用户名和密码,都是guest
可以看到刚刚已经安装的RabbitMQ节点
一般我们都会先创建一个使用的user和virtual host,可以通过rabbitmqctl命令或者管理界面进行创建,我这里就直接在界面操作了。
分配user对我们将要用到的virtual host的权限
到这里为止,就已经完成了RabbitMQ服务的安装了。
自定义配置
RabbitMQ 服务默认监听的端口为5672
,管理插件默认监听的端口为15672
,那如果我们要更改这些端口,应该怎么做呢?
先贴出官网提供的文档链接https://www.rabbitmq.com/configure.html
其实官网说得很详细,我自己整理了一些我有用到的。
首先,RabbitMQ支持通过添加系统环境变量进行定制化配置。
RABBITMQ_NODE_PORT: 默认值为5672
,RabbitMQ服务监听端口
RABBITMQ_NODENAME: Windows系统下默认值为rabbit@%COMPUTERNAME%
,RabbitMQ节点的名称
RABBITMQ_SERVICENAME: 默认值为RabbitMQ
,RabbitMQ服务名称
添加/修改了系统环境变量后,需要重新安装RabbitMQ服务才能生效,是重新安装,不是重启,使用rabbitmq-service命令
再来看看我们创建的RabbitMQ节点的一些信息
这里就包含配置文件路径,数据库文件路径,日志文件路径,默认路径都是在C:\Users\%UserName%\AppData\Roaming\RabbitMQ
目录下,也是可以通过环境变量进行个性化定制
RABBITMQ_CONFIG_FILE: 配置文件路径,默认值为%APPDATA%\RabbitMQ\rabbitmq,官文也特别说明了,配置的时候是不带文件后缀名的
RABBITMQ_ADVANCED_CONFIG_FILE: Advanced配置文件路径,默认值为%APPDATA%\RabbitMQ\advanced,同上,不带文件后缀名
RABBITMQ_MNESIA_DIR: 数据库文件路径,默认值为%APPDATA%\RabbitMQ$RABBITMQ_NODENAME
到了这里,我在做实际操作的时候是有疑问的,因为出现了三个文件分别是rabbitmq.conf
, rabbitmq.config
, advanced.config
,特别是前面两个,一开始我一度认为只是官文不小心写错了,它们说的应该是同一个文件,然而并不是,而且这两个配置文件的写法也不一样,我又仔细看了看上面链接的官文,自己也做了一下实验,得到了下面的结论(如果有不对的,各路大神请指正)。
rabbitmq.config
为RabbitMQ 3.7.0之前使用的默认配置文件,写法使用的是Erlang格式,rabbitmq.conf
是RabbitMQ 3.7.0版本开始使用的默认配置文件,写法使用的是sysctl格式。而advanced.config
则是因为有一些配置无法或者很难用sysctl格式进行书写的,那就写在这个advanced.config
文件中,所以advanced.config
的写法使用的是Erlang格式。
旧版Erlang格式
[
{rabbit, [{ssl_options, [{cacertfile, "/path/to/ca_certificate.pem"},
{certfile, "/path/to/server_certificate.pem"},
{keyfile, "/path/to/server_key.pem"},
{verify, verify_peer},
{fail_if_no_peer_cert, true}]}]}
].
新版sysctl格式
ssl_options.cacertfile = /path/to/ca_certificate.pem
ssl_options.certfile = /path/to/server_certificate.pem
ssl_options.keyfile = /path/to/server_key.pem
ssl_options.verify = verify_peer
ssl_options.fail_if_no_peer_cert = true
然后,为了兼容大家使用的旧版配置文件,新版RabbitMQ也仍然兼容rabbitmq.config
配置,只是在安装服务的时候会有输出提示让大家尽快升级到新版。
那么这个时候就会有一个问题了,上面我们的环境变量RABBITMQ_CONFIG_FILE
是说不包含文件后缀名的,那如果我两个文件同时存在,到底会是哪个配置文件被优先使用呢?
- 如果
rabbitmq.config
、rabbitmq.conf
文件都不存在,优先使用advanced.config
中的配置 - 只要
rabbitmq.config
存在,优先使用rabbitmq.config
文件,直接忽略advanced.config
文件 - 如果
rabbitmq.config
不存在,而rabbitmq.conf
、advanced.config
同时存在,则这两个文件都会被使用
如果我们指定RABBITMQ_CONFIG_FILE
为其它文件名或者其它路径,情况也是参考如上。
这里还有一个环境变量RABBITMQ_CONF_ENV_FILE
,在Windows系统中对应的是一个批处理文件,通常命名为rabbitmq-env-conf.bat
,只要我们配置了这个环境变量,那么刚刚前面我们提到的环境变量,都可以在这个批处理文件中添加,如下:
set RABBITMQ_CONFIG_FILE=D:\RabbitMQ\myrabbitmq.config
也是要注意的,记得重新安装服务。
所以回到我们一开始的问题,怎么修改RabbitMQ服务监听端口和管理插件监听端口?
- 通过环境变量
RABBITMQ_NODE_PORT
可以修改RabbitMQ服务监听端口 - 通过
rabbitmq.config
、advanced.config
添加如下配置,使用Erlang格式:
[
{rabbit, [
{tcp_listeners, [5675]}
]
},
{rabbitmq_management, [
{listener, [{port, 15675}]}
]
}
].
- 通过
rabbitmq.conf
添加如下配置,使用sysctl格式:
listeners.tcp.default = 5675
management.tcp.port = 15675
更多的配置项,可以查看官文https://www.rabbitmq.com/configure.html#config-items、https://www.rabbitmq.com/management.html,按需配置即可。
附带这三个文件的example文件
rabbitmq.config.example
rabbitmq.conf.example
advanced.config
总结
本文就记录了我在windows系统安装RabbitMQ服务的过程,没有太多的干货,但也确实在百度上能找到关于自定义配置的说明并不多,说得也比较模糊,所以我这里就给自己做了个笔记,下次再用的时候就不会迷路了,希望也能给各位提供一些有用信息。
RabbitMQ的使用(一)- RabbitMQ服务安装的更多相关文章
- RabbitMQ服务安装配置
RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...
- Erlang&RabbitMQ服务安装配置
RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...
- CentOS7下RabbitMQ服务安装配置
参考文档: CentOS7下RabbitMQ服务安装配置 http://www.linuxidc.com/Linux/2016-03/129557.htm 在linux下安装配置rabbitMQ详细教 ...
- CentOS7下RabbitMQ服务安装配置胜多负少
RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...
- CentOS7下RabbitMQ服务安装配置 (亲测有效)
erlang 21.3 rabbitmq-server 3.7.14 下载地址 链接: https://pan.baidu.com/s/1g_T1Q_6zpyO3AepS0ZPgYQ 提取码: abq ...
- 用 Python、 RabbitMQ 和 Nameko 实现微服务
用 Python. RabbitMQ 和 Nameko 实现微服务 原创 07-17 17:57 首页 Linux中国 "微服务是一股新浪潮" - 现如今,将项目拆分成多个独立的. ...
- 初识RabbitMQ系列之二:下载安装
一:Erlang安装 因为RabbitMQ 是Erlang语言开发的,所以首先要装上Erlang的环境 1)下载Erlang 下载官网:http://www.erlang.org/downloa ...
- RabbitMQ在windows环境下的安装
最近一直想入手一台电脑,作为linux服务器,由于经济状况也没有入手,现在就先介绍windows环境下安装rabbitMQ. RabbitMQ是什么 ? RabbitMQ是一个在AMQP基础上完整的, ...
- Python3.7.1学习(六)RabbitMQ在Windows环境下的安装
Windows下安装RabbitMQ 环境配置 部署环境 部署环境:windows server 2008 r2 enterprise(本文安装环境Win7) 官方安装部署文档:http://www. ...
随机推荐
- 【Mongodb】视图 && 索引
准备工作 准备2个集合的数据,后面视图和索引都会用到1个订单集合,一个收款信息集合 var orders = new Array(); var shipping = new Array(); var ...
- 教你爬取腾讯课堂、网易云课堂、mooc等所有课程信息
本文的所有代码都在GitHub上托管,想要代码的同学请点击这里
- [转] [腾讯游戏学院] Roguelike到底是什么?
如果你是一位资深游戏玩家,那么最近你肯定在哪里看到过 Roguelike 这个词.Roguelike 这个古老的游戏类型现在又变得很潮流,其中各种要素都在不断的被新游戏借鉴.作为一名就是比你有更多空余 ...
- C#多线程(6):线程通知
目录 AutoRestEvent 类 常用方法 一个简单的示例 解释一下 复杂一点的示例 解释 回顾一下,前面 lock.Monitor 部分我们学习了线程锁,Mutex 部分学习了进程同步,Sema ...
- Salesforce Admin考题解析 | 流程自动化考题与知识点拓展
[题目1] A record is modified on 1/1/2008. It meets criteria for a time-based workflow rule; this rule ...
- 给想学python但还没有接触过的你,python代码的书写规则,小白入门
Python 文件结构 变量命名 注释 单行注释 多行注释 缩进 Python 文件结构 #!/usr/bin/env python3 # 指定python解释器 # -*- coding: utf- ...
- vue单页应用和和多页应用的区别
个人见解如下: 单页面应用(SinglePage Web Application )简称:SPA 多页面应用 (MultiPage Application) 简称:MPA 组成一个外壳和多个页面片段 ...
- 架构师修炼之微服务部署 - Docker简介
Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器或Windows 机器上,也可以实现虚拟化,容器是 ...
- Linux学习笔记(五)搜索命令
搜索命令 whereis which locate find whereis 英文原意:locate the binary,source,and manual page files for a com ...
- 挑战全网最幽默的Vuex系列教程:第三讲 Vuex旗下的Mutation
写在前面 上一讲「Vuex 旗下的 State 和 Getter」,告诉了我们怎么去使用仓库 store 中的状态数据.当然,光会用肯定还不够,大部分的应用场景还得对这些状态进行操控,那么具体如何操控 ...