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命令如下,按需执行:

  1. # 安装RabbitMQ服务
  2. rabbitmq-service install
  3. # 启动RabbitMQ服务
  4. rabbitmq-service start
  5. # 停止RabbitMQ服务
  6. rabbitmq-service stop
  7. # 删除RabbitMQ服务
  8. rabbitmq-service remove

启用RabbitMQ管理插件

  1. #cmd命令
  2. 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格式

  1. [
  2. {rabbit, [{ssl_options, [{cacertfile, "/path/to/ca_certificate.pem"},
  3. {certfile, "/path/to/server_certificate.pem"},
  4. {keyfile, "/path/to/server_key.pem"},
  5. {verify, verify_peer},
  6. {fail_if_no_peer_cert, true}]}]}
  7. ].

新版sysctl格式

  1. ssl_options.cacertfile = /path/to/ca_certificate.pem
  2. ssl_options.certfile = /path/to/server_certificate.pem
  3. ssl_options.keyfile = /path/to/server_key.pem
  4. ssl_options.verify = verify_peer
  5. ssl_options.fail_if_no_peer_cert = true

然后,为了兼容大家使用的旧版配置文件,新版RabbitMQ也仍然兼容rabbitmq.config配置,只是在安装服务的时候会有输出提示让大家尽快升级到新版。

那么这个时候就会有一个问题了,上面我们的环境变量RABBITMQ_CONFIG_FILE是说不包含文件后缀名的,那如果我两个文件同时存在,到底会是哪个配置文件被优先使用呢?

  • 如果rabbitmq.configrabbitmq.conf文件都不存在,优先使用advanced.config中的配置
  • 只要rabbitmq.config存在,优先使用rabbitmq.config文件,直接忽略advanced.config文件
  • 如果rabbitmq.config不存在,而rabbitmq.confadvanced.config同时存在,则这两个文件都会被使用

如果我们指定RABBITMQ_CONFIG_FILE为其它文件名或者其它路径,情况也是参考如上。

这里还有一个环境变量RABBITMQ_CONF_ENV_FILE,在Windows系统中对应的是一个批处理文件,通常命名为rabbitmq-env-conf.bat,只要我们配置了这个环境变量,那么刚刚前面我们提到的环境变量,都可以在这个批处理文件中添加,如下:

  1. set RABBITMQ_CONFIG_FILE=D:\RabbitMQ\myrabbitmq.config

也是要注意的,记得重新安装服务。

所以回到我们一开始的问题,怎么修改RabbitMQ服务监听端口和管理插件监听端口?

  1. 通过环境变量RABBITMQ_NODE_PORT可以修改RabbitMQ服务监听端口
  2. 通过rabbitmq.configadvanced.config添加如下配置,使用Erlang格式:
  1. [
  2. {rabbit, [
  3. {tcp_listeners, [5675]}
  4. ]
  5. },
  6. {rabbitmq_management, [
  7. {listener, [{port, 15675}]}
  8. ]
  9. }
  10. ].
  1. 通过rabbitmq.conf添加如下配置,使用sysctl格式:
  1. listeners.tcp.default = 5675
  2. management.tcp.port = 15675

更多的配置项,可以查看官文https://www.rabbitmq.com/configure.html#config-itemshttps://www.rabbitmq.com/management.html,按需配置即可。

附带这三个文件的example文件

rabbitmq.config.example

rabbitmq.conf.example

advanced.config

总结

本文就记录了我在windows系统安装RabbitMQ服务的过程,没有太多的干货,但也确实在百度上能找到关于自定义配置的说明并不多,说得也比较模糊,所以我这里就给自己做了个笔记,下次再用的时候就不会迷路了,希望也能给各位提供一些有用信息。

RabbitMQ的使用(一)- RabbitMQ服务安装的更多相关文章

  1. RabbitMQ服务安装配置

    RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...

  2. Erlang&RabbitMQ服务安装配置

    RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...

  3. CentOS7下RabbitMQ服务安装配置

    参考文档: CentOS7下RabbitMQ服务安装配置 http://www.linuxidc.com/Linux/2016-03/129557.htm 在linux下安装配置rabbitMQ详细教 ...

  4. CentOS7下RabbitMQ服务安装配置胜多负少

    RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.RabbitMQ据说具有良 ...

  5. CentOS7下RabbitMQ服务安装配置 (亲测有效)

    erlang 21.3 rabbitmq-server 3.7.14 下载地址 链接: https://pan.baidu.com/s/1g_T1Q_6zpyO3AepS0ZPgYQ 提取码: abq ...

  6. 用 Python、 RabbitMQ 和 Nameko 实现微服务

    用 Python. RabbitMQ 和 Nameko 实现微服务 原创 07-17 17:57 首页 Linux中国 "微服务是一股新浪潮" - 现如今,将项目拆分成多个独立的. ...

  7. 初识RabbitMQ系列之二:下载安装

    一:Erlang安装 因为RabbitMQ 是Erlang语言开发的,所以首先要装上Erlang的环境 1)下载Erlang    下载官网:http://www.erlang.org/downloa ...

  8. RabbitMQ在windows环境下的安装

    最近一直想入手一台电脑,作为linux服务器,由于经济状况也没有入手,现在就先介绍windows环境下安装rabbitMQ. RabbitMQ是什么 ? RabbitMQ是一个在AMQP基础上完整的, ...

  9. Python3.7.1学习(六)RabbitMQ在Windows环境下的安装

    Windows下安装RabbitMQ 环境配置 部署环境 部署环境:windows server 2008 r2 enterprise(本文安装环境Win7) 官方安装部署文档:http://www. ...

随机推荐

  1. 【Mongodb】视图 && 索引

    准备工作 准备2个集合的数据,后面视图和索引都会用到1个订单集合,一个收款信息集合 var orders = new Array(); var shipping = new Array(); var ...

  2. 教你爬取腾讯课堂、网易云课堂、mooc等所有课程信息

    本文的所有代码都在GitHub上托管,想要代码的同学请点击这里

  3. [转] [腾讯游戏学院] Roguelike到底是什么?

    如果你是一位资深游戏玩家,那么最近你肯定在哪里看到过 Roguelike 这个词.Roguelike 这个古老的游戏类型现在又变得很潮流,其中各种要素都在不断的被新游戏借鉴.作为一名就是比你有更多空余 ...

  4. C#多线程(6):线程通知

    目录 AutoRestEvent 类 常用方法 一个简单的示例 解释一下 复杂一点的示例 解释 回顾一下,前面 lock.Monitor 部分我们学习了线程锁,Mutex 部分学习了进程同步,Sema ...

  5. Salesforce Admin考题解析 | 流程自动化考题与知识点拓展

    [题目1] A record is modified on 1/1/2008. It meets criteria for a time-based workflow rule; this rule ...

  6. 给想学python但还没有接触过的你,python代码的书写规则,小白入门

    Python 文件结构 变量命名 注释 单行注释 多行注释 缩进 Python 文件结构 #!/usr/bin/env python3 # 指定python解释器 # -*- coding: utf- ...

  7. vue单页应用和和多页应用的区别

    个人见解如下: 单页面应用(SinglePage Web Application  )简称:SPA 多页面应用 (MultiPage Application) 简称:MPA 组成一个外壳和多个页面片段 ...

  8. 架构师修炼之微服务部署 - Docker简介

    Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器或Windows 机器上,也可以实现虚拟化,容器是 ...

  9. Linux学习笔记(五)搜索命令

    搜索命令 whereis which locate find whereis 英文原意:locate the binary,source,and manual page files for a com ...

  10. 挑战全网最幽默的Vuex系列教程:第三讲 Vuex旗下的Mutation

    写在前面 上一讲「Vuex 旗下的 State 和 Getter」,告诉了我们怎么去使用仓库 store 中的状态数据.当然,光会用肯定还不够,大部分的应用场景还得对这些状态进行操控,那么具体如何操控 ...