“RabbitMQ:安装部署”的版本间差异

来自Wikioe
跳到导航 跳到搜索
第266行: 第266行:


注意:
注意:
* RabbitMQ 依赖于 Erlang,而 Erlang 内存管理依赖 Socat,因此要首先安装 '''Erlang''' '''socat'''
* RabbitMQ 依赖于 '''Erlang''',而 Erlang 内存管理依赖 '''Socat''',因此要首先安装 Erlang 与 socat;
* Erlang 与 RabbitMQ 版本需要兼容,可以在“'''[https://www.rabbitmq.com/which-erlang.html https://www.rabbitmq.com/which-erlang.html]'''”查看。
* Erlang 与 RabbitMQ 版本需要兼容,可以在“'''[https://www.rabbitmq.com/which-erlang.html https://www.rabbitmq.com/which-erlang.html]'''”查看。
* 离线安装的包,可以自行下载然后上传到服务器,也可以通过服务器的 '''wget''' 工具直接下载:
* 离线安装的包,可以自行下载然后上传到服务器,也可以通过服务器的 '''wget''' 工具直接下载:
*# '''rabbitmq-server包'''下载地址: https://github.com/rabbitmq/rabbitmq-server/releases
*# '''rabbitmq-server包'''下载地址:“'''[https://github.com/rabbitmq/rabbitmq-server/releases https://github.com/rabbitmq/rabbitmq-server/releases]'''”
*# '''erlang包'''下载地址: https://github.com/rabbitmq/erlang-rpm/releases
*# '''erlang包'''下载地址:“'''[https://github.com/rabbitmq/erlang-rpm/releases https://github.com/rabbitmq/erlang-rpm/releases]'''”
*# '''socat包'''下载地址: https://pkgs.org/download/socat 【socat 使用 yum 安装最新版本即可】
*# '''socat包'''下载地址:“'''[https://pkgs.org/download/socat https://pkgs.org/download/socat]'''” 【socat 使用 yum 安装最新版本即可】
* 对于基于RPM的发行版,现代 Erlang 提供了三种替代来源:(Erlang 在默认的 yum 存储库中不可用)
* 对于基于RPM的发行版,现代 Erlang 提供了三种替代来源:(Erlang 在默认的 yum 存储库中不可用)
*# '''RabbitMQ团队''':只提供运行 RabbitMQ 所需的组件,官方称零依赖项,容易安装。【如果Erlang只是用来提供运行RabbitMQ的,推荐使用】
*# '''RabbitMQ团队''':只提供运行 RabbitMQ 所需的组件,官方称'''零依赖项''',容易安装。【如果Erlang只是用来提供运行RabbitMQ的,推荐使用】
*# '''Erlang官方''':通常是相当最新的,并且涉及潜在的过多依赖关系列表的安装。【如果还需要Erlang做相关开发或运行环境,可选择使用】
*# '''Erlang官方''':通常是相当最新的,并且涉及潜在的过多依赖关系列表的安装。【如果还需要Erlang做相关开发或运行环境,可选择使用】
*# '''EPEL源''':这些版本通常已经过时,不能用于运行最新的 RabbitMQ 版本。【不推荐】
*# '''EPEL源''':这些版本通常已经过时,不能用于运行最新的 RabbitMQ 版本。【不推荐】
第287行: 第287行:




步骤如下:【参照 Erlang 与 RabbitMQ 版本要求,以 Erlang 与 RabbitMQ 为例】
步骤如下:【参照 Erlang 与 RabbitMQ 版本要求,以“erlang-23.3.1-1.el7.x86_64.rpm”与“rabbitmq-server-3.8.14-1.el7.noarch.rpm”为例】
# 安装 Erlang:
# 安装 Erlang:
#: <syntaxhighlight lang="bash" highlight="">
#: <syntaxhighlight lang="bash" highlight="">
rpm -Uvh http://www.rabbitmq.com/releases/erlang/erlang-18.1-1.el7.centos.x86_64.rpm
wget https://github.com/rabbitmq/erlang-rpm/releases/download/v23.3.1/erlang-23.3.1-1.el7.x86_64.rpm
rpm -ivh erlang-23.3.1-1.el7.x86_64.rpm
</syntaxhighlight>
</syntaxhighlight>
#: 查看 Erlang 版本:
#: 查看 Erlang 版本:
#: <syntaxhighlight lang="bash" highlight="">
#: <syntaxhighlight lang="bash" highlight="">
erl -version
erl -version
</syntaxhighlight>
# 安装 Socat:
#: <syntaxhighlight lang="bash" highlight="">
wget http://mirror.centos.org/centos/7/os/x86_64/Packages/socat-1.7.3.2-2.el7.x86_64.rpm
rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
# 或者:
yum install socat
</syntaxhighlight>
</syntaxhighlight>
# 安装 RabbitMQ:
# 安装 RabbitMQ:
#: <syntaxhighlight lang="bash" highlight="">
#: <syntaxhighlight lang="bash" highlight="">
rpm -Uvh http://www.rabbitmq.com/releases/rabbitmq-server/v3.5.6/rabbitmq-server-3.5.6-1.noarch.rpm
# 首先导入密钥
rpm -import https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.14/rabbitmq-server-3.8.14-1.el7.noarch.rpm.asc
 
# 下载、安装
wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.14/rabbitmq-server-3.8.14-1.el7.noarch.rpm
rpm -ivh rabbitmq-server-3.8.14-1.el7.noarch.rpm
</syntaxhighlight>
</syntaxhighlight>



2021年5月24日 (一) 01:47的版本


关于

RabbitMQ 快速搭建开发环境,因为 RabbitMQ 使用 Erlang 开发,常规方式安装需要先安装 Erlang,再安装 RabbitMQ 比较麻烦,所以这里推荐使用 Docker 方式部署,一条命令搞定。

CentOS 安装

两种方法可以在 RPM 发行版上安装 RabbitMQ 的最新版本:【转自官网: https://www.rabbitmq.com/install-rpm.html】

  1. 在线安装:使用 Cloudsmith.ioPackageCloud 上的 Yum 存储库安装包。(强烈建议使用此选项)
  2. 离线安装:下载软件包并用 rpm 安装。(需要手动安装所有包依赖项)


  • RabbitMQ RPM 包需要 sudo 权限才能安装和管理。在 sudo 不可用的环境中,可以考虑使用通用二进制构建。

在线安装:使用 Cloudsmith 上的 YUM 库


Cloudsmith 提供了带有 RabbitMQ 包的Yum存储库,还可以通过 yum 安装最新的 Erlang 版本。

安装Yum存储库文件

设置存储库的一种快速方法是使用 Cloudsmith 提供的脚本

【这不是必须的,但是可以考虑使用,因为它将生成的脚本从公共互联网传输到特定的shell】
## Uses a Cloudsmith-provided Yum repository setup script.
## Always verify what is downloaded before piping it to a privileged shell!
curl -1sLf 'https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/setup.rpm.sh' | sudo -E bash


传统的库文件安装方式:【使用上述的命令,可以替代以下步骤】

  1. Yum 将验证其安装的任何包的签名,因此该过程的第一步是导入签名密钥:
    ## primary RabbitMQ signing key
    rpm --import https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    ## modern Erlang repository
    rpm --import 'https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/gpg.E495BB49CC4BBE5B.key'
    ## RabbitMQ server repository
    rpm --import 'https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/gpg.9F4587F226208342.key'
    
  2. 为 RabbitMQ 和 Modern Erlang 添加 Yum 存储库:
    为了使用Yum存储库,必须在 /etc/Yum.repos.d/ 目录下添加一个 .repo 文件(例如“rabbitmq.repo”):
    【.repo 文件根据发行版不同而略有差异,以 CentOS 7 为例】
    # In /etc/yum.repos.d/rabbitmq.repo
    
    [rabbitmq_erlang]
    name=rabbitmq_erlang
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/rpm/el/7/$basearch
    repo_gpgcheck=1
    enabled=1
    # Cloudsmith's repository key and RabbitMQ package signing key
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/gpg.E495BB49CC4BBE5B.key
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    gpgcheck=1
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    
    [rabbitmq_erlang-noarch]
    name=rabbitmq_erlang-noarch
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/rpm/el/7/noarch
    repo_gpgcheck=1
    enabled=1
    # Cloudsmith's repository key and RabbitMQ package signing key
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/gpg.E495BB49CC4BBE5B.key
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    gpgcheck=1
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    
    [rabbitmq_erlang-source]
    name=rabbitmq_erlang-source
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/rpm/el/7/SRPMS
    repo_gpgcheck=1
    enabled=1
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-erlang/gpg.E495BB49CC4BBE5B.key
    gpgcheck=0
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    
    
    ##
    ## RabbitMQ server
    ##
    
    [rabbitmq-server]
    name=rabbitmq_server
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/rpm/el/7/$basearch
    repo_gpgcheck=1
    enabled=1
    # Cloudsmith's repository key and RabbitMQ package signing key
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/gpg.9F4587F226208342.key
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    gpgcheck=1
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    
    [rabbitmq_server-noarch]
    name=rabbitmq_server-noarch
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/rpm/el/7/noarch
    repo_gpgcheck=1
    enabled=1
    # Cloudsmith's repository key and RabbitMQ package signing key
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/gpg.9F4587F226208342.key
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    gpgcheck=1
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    
    [rabbitmq_server-source]
    name=rabbitmq_server-source
    baseurl=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/rpm/el/7/SRPMS
    repo_gpgcheck=1
    enabled=1
    gpgkey=https://dl.cloudsmith.io/public/rabbitmq/rabbitmq-server/gpg.9F4587F226208342.key
    gpgcheck=0
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    pkg_gpgcheck=1
    autorefresh=1
    type=rpm-md
    

用Yum安装包

【操作根据发行版不同而略有差异,以 CentOS 7 为例】

  1. 更新 Yum 软件包元数据:
    yum update -y
    
  2. 然后安装软件包:
    yum install socat logrotate -y
    
    yum install erlang rabbitmq-server -y
    
    • logrotate 程序是一个日志文件管理工具。用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到“转储”作用,可以节省磁盘空间。

在线安装:使用 PackageCloud 上的 YUM 库


PackageCloud 提供了包含 RabbitMQ 包的Yum存储库,也可以用于通过 yum 安装最新的 Erlang 版本。

使用示例:CSDN:Centos7安装RabbitMQ最新版3.8.5,史上最简单实用安装步骤

安装Yum存储库文件

设置存储库的一种快速方法是使用 PackageCloud 提供的脚本

【这不是必须的,但是可以考虑使用,因为它将生成的脚本从公共互联网传输到特定的shell】
## Uses a PackageCloud-provided Yum repository setup script.
## Always verify what is downloaded before piping it to a privileged shell!
curl -s https://packagecloud.io/install/repositories/rabbitmq/rabbitmq-server/script.rpm.sh | sudo bash


传统的库文件安装方式:【使用上述的命令,可以替代以下步骤】

  1. Yum 将验证其安装的任何包的签名,因此该过程的第一步是导入签名密钥:
    ## primary RabbitMQ signing key
    rpm --import https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    ## modern Erlang repository
    rpm --import https://packagecloud.io/rabbitmq/erlang/gpgkey
    ## RabbitMQ server repository
    rpm --import https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey
    
  2. 为 RabbitMQ 和 Modern Erlang 添加 Yum 存储库:
    为了使用Yum存储库,必须在 /etc/Yum.repos.d/ 目录下添加一个 .repo 文件(例如“rabbitmq.repo”):
    【.repo 文件根据发行版不同而略有差异,以 CentOS 7 为例】
    # In /etc/yum.repos.d/rabbitmq.repo
    
    ##
    ## Zero dependency Erlang
    ##
    
    [rabbitmq_erlang]
    name=rabbitmq_erlang
    baseurl=https://packagecloud.io/rabbitmq/erlang/el/7/$basearch
    repo_gpgcheck=1
    gpgcheck=1
    enabled=1
    # PackageCloud's repository key and RabbitMQ package signing key
    gpgkey=https://packagecloud.io/rabbitmq/erlang/gpgkey
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    
    [rabbitmq_erlang-source]
    name=rabbitmq_erlang-source
    baseurl=https://packagecloud.io/rabbitmq/erlang/el/7/SRPMS
    repo_gpgcheck=1
    gpgcheck=0
    enabled=1
    gpgkey=https://packagecloud.io/rabbitmq/erlang/gpgkey
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    
    ##
    ## RabbitMQ server
    ##
    
    [rabbitmq_server]
    name=rabbitmq_server
    baseurl=https://packagecloud.io/rabbitmq/rabbitmq-server/el/7/$basearch
    repo_gpgcheck=1
    gpgcheck=1
    enabled=1
    # PackageCloud's repository key and RabbitMQ package signing key
    gpgkey=https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey
           https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    
    [rabbitmq_server-source]
    name=rabbitmq_server-source
    baseurl=https://packagecloud.io/rabbitmq/rabbitmq-server/el/7/SRPMS
    repo_gpgcheck=1
    gpgcheck=0
    enabled=1
    gpgkey=https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey
    sslverify=1
    sslcacert=/etc/pki/tls/certs/ca-bundle.crt
    metadata_expire=300
    

用Yum安装包

【操作根据发行版不同而略有差异,以 CentOS 7 为例】

  1. 更新 Yum 软件包元数据:
    yum update -y
    
  2. 然后安装软件包:
    ## install these dependencies from standard OS repositories
    yum install socat logrotate -y
    
    yum install --repo rabbitmq_erlang --repo rabbitmq_server erlang rabbitmq-server -y
    
    • logrotate 程序是一个日志文件管理工具。用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到“转储”作用,可以节省磁盘空间。

离线安装


离线安装的最大问题就是需要自行解决依赖项,以及选择兼容的版本。


注意:

  • RabbitMQ 依赖于 Erlang,而 Erlang 内存管理依赖 Socat,因此要首先安装 Erlang 与 socat;
  • Erlang 与 RabbitMQ 版本需要兼容,可以在“https://www.rabbitmq.com/which-erlang.html”查看。
  • 离线安装的包,可以自行下载然后上传到服务器,也可以通过服务器的 wget 工具直接下载:
    1. rabbitmq-server包下载地址:“https://github.com/rabbitmq/rabbitmq-server/releases
    2. erlang包下载地址:“https://github.com/rabbitmq/erlang-rpm/releases
    3. socat包下载地址:“https://pkgs.org/download/socat” 【socat 使用 yum 安装最新版本即可】
  • 对于基于RPM的发行版,现代 Erlang 提供了三种替代来源:(Erlang 在默认的 yum 存储库中不可用)
    1. RabbitMQ团队:只提供运行 RabbitMQ 所需的组件,官方称零依赖项,容易安装。【如果Erlang只是用来提供运行RabbitMQ的,推荐使用】
    2. Erlang官方:通常是相当最新的,并且涉及潜在的过多依赖关系列表的安装。【如果还需要Erlang做相关开发或运行环境,可选择使用】
    3. EPEL源:这些版本通常已经过时,不能用于运行最新的 RabbitMQ 版本。【不推荐】
      • P.S.:如果要使用 EPEL 存储库,需要通过 yum 安装先安装 EPEL 存储库:
        # 先安装epel存储库
        yum -y install epel-release
        
        # 再安装 Erlang、socat
        yum -y install erlang socat
        


步骤如下:【参照 Erlang 与 RabbitMQ 版本要求,以“erlang-23.3.1-1.el7.x86_64.rpm”与“rabbitmq-server-3.8.14-1.el7.noarch.rpm”为例】

  1. 安装 Erlang:
    wget https://github.com/rabbitmq/erlang-rpm/releases/download/v23.3.1/erlang-23.3.1-1.el7.x86_64.rpm
    rpm -ivh erlang-23.3.1-1.el7.x86_64.rpm
    
    查看 Erlang 版本:
    erl -version
    
  2. 安装 Socat:
    wget http://mirror.centos.org/centos/7/os/x86_64/Packages/socat-1.7.3.2-2.el7.x86_64.rpm
    rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
    
    # 或者:
    yum install socat
    
  3. 安装 RabbitMQ:
    # 首先导入密钥
    rpm -import https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.14/rabbitmq-server-3.8.14-1.el7.noarch.rpm.asc
    
    # 下载、安装
    wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.14/rabbitmq-server-3.8.14-1.el7.noarch.rpm
    rpm -ivh rabbitmq-server-3.8.14-1.el7.noarch.rpm
    

启动

#启动服务
systemctl start rabbitmq-server

#查看状态
systemctl status rabbitmq-server

#设置为开机启动
systemctl enable rabbitmq-server

启用管理平台插件

rabbitmq-plugins enable rabbitmq_management



Docker方式部署

可以到docker官方镜像仓库找最新版本:https://hub.docker.com/_/rabbitmq

安装

docker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management

其中:

  • 下载并且启动了一个 rabbitmq 容器实例;
  • 开放了两个端口:5672(代码访问使用)和 15672(管理后台使用);
  • 使用的是 3-management 版本;

容器维护

  1. 关闭 RabbitMQ 容器:
    docker stop rabbitmq
    
  2. 启动 RabbitMQ 容器:
    docker start rabbitmq
    

管理后台

RabbitMQ提供了一个可视化的Web后台,方便了解队列的运行情况,也可以对RabbitMQ做一些管理操作。


访问 RabbitMQ 管理后台地址:http://localhost:15672/

RabbitMQ:管理后台.png
  • 默认账号和密码:guest / guest

后台首页

RabbitMQ:管理后台:后台首页.png

客户端连接情况

RabbitMQ:管理后台:客户端连接情况.png

交换机情况

RabbitMQ:管理后台:交换机情况.png

队列情况

RabbitMQ:管理后台:队列情况.png

队列详情

RabbitMQ:管理后台:队列详情.png