当前位置: 首页 > article >正文

麒麟银河V10服务器RabbitMQ安装

安装步骤

rabbitMQ依赖于erlang的环境,所以需要先安装erlang,erlang跟rabbitMQ是有版本之间的关联关系的,根据对应的版本去安装下载,保证少出问题。
可以通过官网来查看RabbitMQ和erlang之间的版本对应关系
rabbitMQ和erlang之间的版本对应关系官网链接

https://www.rabbitmq.com/docs/which-erlang

在这里插入图片描述
不同的服务器有不同的架构模式,我这里以国产化服务器麒麟银河V10为准,麒麟银河V10的架构协议是aarch64,如果不知道自己的服务器是什么架构模式的可以通过命令

uname -m

来查看是什么架构模式的服务器。
在这里插入图片描述

麒麟银河V10安装运行

下载erlang

下载地址

https://www.rabbitmq.com/docs/download

rabbitMQ是以erlang为基础来运行的,所以我们先下载erlang,在下载链接里面找到这个位置

在这里插入图片描述
按照这个步骤,点击5后,跳转到gitHub页面,点击Tags,然后跳转到版本内容里,选择Releases,展示出来的是各个erlang版本的列表,选择跟你想要的rabbitMq的版本对应的erlang版本即可,Assets内选择对应的服务器架构的rpm文件进行下载即可。在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

下载RabbitMQ

下载完erlang以后,下载RabbitMQ,还是刚才看RabbitMQ和erlang对应关系的网站,选择下载CentOS的链接。
在这里插入图片描述
选择以后跳转到图片位置,可以搜索一下Direct Downloads标题,点击下载即可。(centOS的包在麒麟V10里可以直接用,目前没有麒麟V10的版本)
在这里插入图片描述

安装运行

RabbitMQ和erlang都下载完成后,就可以安装了,把安装包放到linux的目录下,执行 rpm -ivh 安装命令。

安装命令:

安装erlang:rpm -ivh erlang-27.3-1.el8.aarch64.rpm
安装rabbitMQ:rpm -ivh rabbitmq-server-4.0.7-1.el8.noarch.rpm

安装完成后使用 systemctl rabbitmq-server start 命令启动mq

[root@Centos7 rabbitmq]# service rabbitmq-server start
Redirecting to /bin/systemctl start rabbitmq-server.service
Job for rabbitmq-server.service failed because the control process exited with error code. See "systemctl status rabbitmq-server.service" and "journalctl -xe" for details.
重启命令:systemctl restart rabbitmq-server
状态查看命令:systemctl status rabbitmq-server

开启web页面

使用rabbitmq-plugins enable rabbitmq_management命令开启web页面,注意开启后需要使用systemctl restart rabbitmq-server命令重启rabbitmq服务
重启后,就可以通过http://localhost:15672来访问管理端页面了。
在这里插入图片描述

创建用户

默认rabbitMQ是guest用户,账号密码都是guest,但是只能本地登录,远程登录需要重新创建用户。

新增用户

创建用户,用户密码都是admin

rabbitmqctl add_user admin admin

设置用户分配操作权限

rabbitmqctl set_user_tags admin administrator

administrator 为用户级别,所有的级别为:

  • administrator 可以登录控制台、查看所有信息、可以对rabbitmq进行管理
  • monitoring 监控者,可登录控制台,查看所有信息
  • policymaker 策略制定者, 可登录控制台,指定策略
  • managment 普通管理员,可登录控制台

为用户添加资源权限

rabbitmqctl set_permissions -p / 用户名 ".*" ".*" ".*"
  • -p /: –p 参数后面跟的是虚拟主机名称,这里 / 表示默认的根虚拟主机。
  • admin: 这是设置权限的用户账号。通常用于管理员操作。
  • “.“: 这是一个通配符模式,意味着对这个用户赋予了所有权限。”” 代表任意字符,. 代表任意单个字符。
  • “." 和
    ".
    ”:这两个同样是指定该用户可以执行的所有操作,也是全部权限的表示。

这条命令的作用就是给用户 admin/ 虚拟主机上设置了完全权限,这意味着 admin 用户可以执行所有的操作,包括但不限于创建、删除队列,发布、取消消息等。

控制台执行如下命令:

[root@Centos7 rabbitmq]# rabbitmqctl add_user admin admin
Adding user "admin" ...
Done. Don't forget to grant the user permissions to some virtual hosts! See 'rabbitmqctl help set_permissions' to learn more.
[root@Centos7 rabbitmq]# rabbitmqctl set_user_tags admin administrator
Setting tags for user "admin" to [administrator] ...
[root@Centos7 rabbitmq]# rabbitmqctl set_permissions -p / admin  ".*" ".*" ".*"
Setting permissions for user "admin" in vhost "/" ...

使用新账号登录
在这里插入图片描述
进入后在Admin页签中如下图,用户处多了新加的admin
在这里插入图片描述
至此安装运行完成。
其他用户操作命令:

rabbitmqctl change_password Username Newpassword 修改密码
rabbitmqctl delete_user Username 删除用户
rabbitmqctl list_users 查看用户清单

Docker安装

docker安装rabbitmq访问地址

docker安装访问地址:https://www.rabbitmq.com/docs/download

在这里插入图片描述
复制docker安装命令,粘贴到安装好docker的linux服务器上即可。

# latest RabbitMQ 4.0.x
docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:4.0-management

docker命令会自动安装rabbitmq,只需要等待即可。

[root@Centos7 ~]# docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:4.0-management
Unable to find image 'rabbitmq:4.0-management' locally
4.0-management: Pulling from library/rabbitmq
afad30e59d72: Already exists 
211e97f904c7: Already exists 
b7d633cb09df: Already exists 
0357761da170: Already exists 
ca95b127b98a: Already exists 
3ec3ceaa0dcb: Already exists 
7037c52023fb: Already exists 
d738327fa668: Already exists 
5a286d22c8dd: Already exists 
e971f4d4bd73: Pull complete 
Digest: sha256:a0ea806ba32e6e9776aa83f66796e6c746606e669220b26359bd461c79a2ba14
Status: Downloaded newer image for rabbitmq:4.0-management
.........
2024-11-22 01:53:31.112725+00:00 [info] <0.9.0> Time to start RabbitMQ: 3371 ms

下载成功后,他是命令行控制台运行的,不是后台运行,直接停止,然后换为后台运行即可。

[root@Centos7 ~]# docker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:4.0-management
7a462270fd1154dsjfh474awr645sffsjfhsaf15454de63ccb0ddad

如果不了解docker命令的,建议先去学习一下docker。

查看版本信息

[root@Centos7 ~]# docker run --rm rabbitmq rabbitmqctl version
4.0.3

docker开启rabbitMQ管理界面

首先需要进入docker的rabbitMQ内部
#查看docker运行服务的状态
[root@bogon /]# docker ps
CONTAINER ID   IMAGE             COMMAND                   CREATED          STATUS          PORTS                                                                                                                                      NAMES
7a462270fd11   rabbitmq:latest   "docker-entrypoint.s…"   13 minutes ago   Up 13 minutes   4369/tcp, 5671/tcp, 15691-15692/tcp, 25672/tcp, 0.0.0.0:5673->5672/tcp, :::5673->5672/tcp, 0.0.0.0:15673->15672/tcp, :::15673->15672/tcp   rabbitmq
#进入rabbitmq
[root@bogon /]# docker exec -it rabbitmq /bin/bash
root@7a462270fd11:/# 
开启图形管理界面
root@7a462270fd11:/# rabbitmq-plugins enable rabbitmq_management
Enabling plugins on node rabbit@7a462270fd11:
rabbitmq_management
The following plugins have been configured:rabbitmq_managementrabbitmq_management_agentrabbitmq_prometheusrabbitmq_web_dispatch
Applying plugin configuration to rabbit@7a462270fd11...
The following plugins have been enabled:rabbitmq_managementstarted 1 plugins.
root@7a462270fd11:/# 

在RabbitMQ容器成功启动后,可以通过浏览器访问其管理界面来监控和管理RabbitMQ实例。以下是如何打开RabbitMQ管理界面的步骤:

确认宿主机的IP地址或域名。如果您在本地部署,可以使用localhost127.0.0.1。如果您在远程服务器或虚拟机上部署,需要使用相应的IP地址或域名。

使用浏览器打开RabbitMQ管理界面。默认情况下,管理界面端口为15673。在浏览器地址栏输入以下URL:

http://<宿主机IP地址>:15673

例如,如果您在本地部署,可以访问:

http://localhost:15673

等待页面加载完成。如果一切配置正确,您将看到RabbitMQ管理界面的登录页面。账号密码跟在服务器安装是一样的,也是guest
在这里插入图片描述

docker操作rabbitMQ命令

停止RabbitMQ容器:docker stop rabbitmq启动RabbitMQ容器:docker start rabbitmq查看节点状态:docker exec rabbitmq rabbitmqctl status

docker操作rabbitMQ添加用户和设置权限

跟直接在服务器安装分配权限命令一致,只是添加了docker命令的操作。

添加用户
docker exec rabbitmq rabbitmqctl add_user admin admin
设置用户权限
#分配用户操作权限
docker exec rabbitmq rabbitmqctl set_user_tags admin administrator
#添加用户资源权限
docker exec rabbitmq rabbitmqctl set_permissions -p / admin ".*" ".*" ".*"

卸载RabbitMQ命令

先停止RabbitMQ

systemctl stop rabbitmq-server

查看并卸载rabbitmq安装的相关列表

查看命令:yum list | grep rabbitmq卸载命令(直接执行即可):yum -y remove rabbitmq-server.noarch

查看并卸载erlang安装的相关软件包

查看命令:yum list | grep erlang卸载命令(直接执行即可):yum -y remove erlang-*

查找并删除erlang相关文件

whereis erlang[root@Centos7 ~]# whereis erlang
erlang: /usr/lib64/erlang删除上面查出的erlang相关文件:
[root@Centos7 ~]# rm -rf /usr/lib64/erlang

卸载完成。

相关文章:

麒麟银河V10服务器RabbitMQ安装

安装步骤 rabbitMQ依赖于erlang的环境&#xff0c;所以需要先安装erlang&#xff0c;erlang跟rabbitMQ是有版本之间的关联关系的&#xff0c;根据对应的版本去安装下载&#xff0c;保证少出问题。 可以通过官网来查看RabbitMQ和erlang之间的版本对应关系 rabbitMQ和erlang之间…...

‌React Hooks主要解决什么

1、‌状态逻辑复用困难 在Hooks出现之前&#xff0c;React组件间的状态逻辑复用主要依赖高阶组件&#xff08;HOC&#xff09;和 render props。 Hooks 通过允许创建自定义Hook&#xff0c;使得状态逻辑的复用变得简单而直接‌ 缺点 HOC 可能导致 props 命名冲突render props …...

extern和static的作用(有例子)

一、extern extern的作用 声明而非定义 extern告诉编译器某个变量或函数存在于其他地方&#xff08;通常是另一个源文件&#xff09;&#xff0c;当前只是声明它&#xff0c;而不是定义它&#xff08;分配内存&#xff09;。定义只能在一个地方出现&#xff0c;而声明可以多次…...

基于C#的以太网通讯实现:TcpClient异步通讯详解

基于C#的以太网通讯实现&#xff1a;TcpClient异步通讯详解 在现代工业控制和物联网应用中&#xff0c;以太网通讯是一种常见的数据传输方式。本文将介绍如何使用C#实现基于TCP协议的以太网通讯&#xff0c;并通过异步编程提高通讯效率。我们将使用TcpClient类来实现客户端与服…...

【8】分块学习笔记

前言 分块是一种重要的高级数据结构思想&#xff0c;核心为大段维护&#xff0c;局部朴素。 顺带一提&#xff0c;由于个人技术水平,本篇博客的难度并没有标题所述的 8 8 8 级。分块还是很难的。 分块 分块&#xff0c;是“优雅的暴力”。 分块的基本思想是把数据分为若干…...

Deployment声明式更新与应用式更新对比

目录 1. 声明式更新 特点 相关命令 示例 2. 命令式更新 特点 相关命令 示例 3. 声明式更新 vs 命令式更新 4. 声明式更新的优势 5. 命令式更新的适用场景 6. 总结 在 Kubernetes 中&#xff0c;声明式更新和命令式更新是两种不同的资源管理方式。它们分别通过不同的…...

【蓝桥杯】省赛:分糖果(思维/模拟)

思路 数据很小&#xff0c;直接暴力模拟。 有意思的是一个列表如何当成循环队列写&#xff1f;可以arr[(i1)%n]让他右边超出时自动回到开头。 code import os import sysn int(input()) arr list(map(int,input().split()))ans 0 while 1:arr1 arr.copy()for i in range…...

在 Go 语言中生成单元测试报告

在 Go 语言中生成单元测试报告&#xff0c;你可以使用 go test 命令配合一些参数来实现。以下是一些常用的方法和步骤&#xff1a; 基本测试&#xff1a;首先&#xff0c;确保你的项目已经编写了测试文件&#xff08;通常以 _test.go 结尾&#xff09;。然后&#xff0c;在项目…...

Metasploit Framework(MSF)使用教程与命令详解

Metasploit Framework&#xff08;简称MSF&#xff09;是一款功能强大的开源渗透测试工具&#xff0c;广泛应用于网络安全领域。它集成了大量的漏洞利用模块&#xff08;exploits&#xff09;、辅助模块&#xff08;auxiliary&#xff09;和载荷&#xff08;payloads&#xff0…...

进程间通信(1)——管道

1. 进程间通信简介 进程间通信&#xff08;Inter-Process Communication&#xff0c;IPC&#xff09;是指不同进程之间交换数据的机制。由于进程具有独立的地址空间&#xff0c;它们无法直接访问彼此的数据&#xff0c;因此需要IPC机制来实现信息共享、数据传递或同步操作。 …...

python基础8 单元测试

通过前面的7个章节&#xff0c;作者学习了python的各项基础知识&#xff0c;也学习了python的编译和执行。但在实际环境上&#xff0c;我们需要验证我们的代码功能符合我们的设计预期&#xff0c;所以需要结合python的单元测试类&#xff0c;编写单元测试代码。 Python有一个内…...

【正点原子K210连载】第七十六章 音频FFT实验 摘自【正点原子】DNK210使用指南-CanMV版指南

第七十六章 音频FFT实验 本章将介绍CanMV下FFT的应用&#xff0c;通过将时域采集到的音频数据通过FFT为频域。通过本章的学习&#xff0c;读者将学习到CanMV下控制FFT加速器进行FFT的使用。 本章分为如下几个小节&#xff1a; 32.1 maix.FFT模块介绍 32.2 硬件设计 32.3 程序设…...

【杂记二】git, github, vscode等

一、前言 暂时空着... 二、git 2.1 可能的疑问 1. VSCode 项目名和 GitHub 仓库名是否需要一致&#xff1f; 不需要一致。 VSCode 项目名&#xff08;也就是你本地的文件夹名字&#xff09;和 GitHub 仓库名可以不一样。 Git 是一个分布式版本控制系统&#xff0c;它主要关…...

《基于Spring Boot+Vue的智慧养老系统的设计与实现》开题报告

个人主页:@大数据蟒行探索者 一、研究背景及国内外研究现状 1.研究背景 根据1982年老龄问题世界大会联合国制定的标准,如果一个国家中超过65岁的老人占全国总人口的7%以上,或者超过60岁的老人占全国总人口的10%以上,那么这个国家将被定义为“老龄化社会”[1]。 随着国…...

ModBus TCP/RTU互转(主)(从)|| Modbus主动轮询下发的工业应用 || 基于智能网关的串口服务器进行Modbus数据收发的工业应用

目录 前言 一、ModBus TCP/RTU互转&#xff08;从&#xff09;及应用|| 1.1 举栗子 二、ModBus TCP/RTU互转&#xff08;主&#xff09; 2.1 举栗子 三、ModBus 主动轮询 3.1 Modbus主动轮询原理 3.2 Modbus格式上传与下发 3.2.1.设置Modbus主动轮询指令 3.2.2 设…...

【设计模式】3W 学习法深入剖析创建型模式:原理、实战与开源框架应用(含 Java 代码)

3W 学习法总结创建型模式&#xff08;附 Java 代码实战及开源框架应用&#xff09; 创建型模式主要关注 对象的创建&#xff0c;旨在提高代码的可复用性、可扩展性和灵活性。本文采用 3W 学习法&#xff08;What、Why、How&#xff09;&#xff0c;深入分析 五大创建型模式&am…...

Jobby、Quarkus 和 Spring Boot对比

Jobby、Quarkus 和 Spring Boot 是三种不同的 Java 框架&#xff0c;各自有不同的设计目标和适用场景。以下是对它们的详细对比&#xff1a; 1. 设计目标 框架设计目标Jobby轻量级的任务调度框架&#xff0c;专注于任务调度和执行。Quarkus面向云原生和 Kubernetes 的 Java 框…...

[代码规范]1_良好的命名规范能减轻工作负担

欢迎来到啾啾的博客&#x1f431;&#xff0c;一个致力于构建完善的Java程序员知识体系的博客&#x1f4da;&#xff0c;记录学习的点滴&#xff0c;分享工作的思考、实用的技巧&#xff0c;偶尔分享一些杂谈&#x1f4ac;。 欢迎评论交流&#xff0c;感谢您的阅读&#x1f604…...

【HarmonyOS Next之旅】DevEco Studio使用指南(三)

目录 1 -> 一体化工程迁移 1.1 -> 自动迁移 1.2 -> 手动迁移 1.2.1 -> API 10及以上历史工程迁移 1.2.2 -> API 9历史工程迁移 1 -> 一体化工程迁移 DevEco Studio从 NEXT Developer Beta1版本开始&#xff0c;提供开箱即用的开发体验&#xff0c;将SD…...

冯・诺依曼架构深度解析

一、历史溯源&#xff1a;计算机科学的革命性突破 1.1 前冯・诺依曼时代 在 1940 年代之前&#xff0c;计算机领域呈现 "百家争鸣" 的格局&#xff1a; 哈佛 Mark I&#xff08;1944&#xff09;&#xff1a;采用分离的指令存储与数据存储ENIAC&#xff08;1946&a…...

gralloc1_perform具体在干什么

gralloc1_perform 会在特定场景下通过 ioctl 调用&#xff0c;执行 缓存 (cache) 管理 和 内存映射 操作&#xff0c;确保 CPU 和 GPU 之间的数据一致性。 &#x1f4cc; 为什么需要对 cache 进行操作&#xff1f; 在 Android 系统中&#xff0c;CPU 和 GPU 通常共享 DDR 内存…...

安装配置Anaconda,配置VSCode

文章目录 Anaconda介绍下载Anaconda安装Anaconda换源创建一个新环境conda常用命令 VSCode环境配置 记录一下笔者收集的一些资料&#xff0c;不喜勿喷。 Anaconda介绍 Anaconda是一个用于科学计算的Python发行版&#xff0c;支持 Linux, Mac, Windows系统&#xff0c;提供了包管…...

【愚公系列】《高效使用DeepSeek》017-知识点思维导图生成

🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...

【量化策略】网格交易策略

【量化策略】网格交易策略 &#x1f680;量化软件开通 &#x1f680;量化实战教程 技术背景与应用场景 网格交易策略是一种基于市场波动性的自动化交易方法&#xff0c;适用于震荡市场。它通过在预设的价格区间内设置多个买卖点&#xff0c;自动执行低买高卖的操作&#xf…...

C++ 语法之函数和函数指针

在上一章中 C 语法之 指针的一些应用说明-CSDN博客 我们了解了指针变量&#xff0c;int *p;取变量a的地址这些。 那么函数同样也有个地址&#xff0c;直接输出函数名就可以得到地址&#xff0c;如下&#xff1a; #include<iostream> using namespace std; void fun() …...

网络协议抓取与分析(SSL Pinning突破)

1. 网络协议逆向基础 1.1 网络协议分析流程 graph TD A[抓包环境配置] --> B[流量捕获] B --> C{协议类型} C -->|HTTP| D[明文解析] C -->|HTTPS| E[SSL Pinning突破] D --> F[参数逆向] E --> F F --> G[协议重放与模拟] 1.1.1 关键分析目标…...

蓝桥杯真题——洛谷Day13 找规律(修建灌木)、字符串(乘法表)、队列(球票)

目录 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 字符串 P8723 [蓝桥杯 2020 省 AB3] 乘法表 队列 P8641 [蓝桥杯 2016 国 C] 赢球票 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 思路&#xff1a;对某个特定的点来说有向前和向后的情况&#xff0c;即有向前再返回到该位置…...

【2025】基于Springboot + vue实现的毕业设计选题系统

项目描述 本系统包含管理员、学生、教师三个角色。 管理员角色&#xff1a; 用户管理&#xff1a;管理系统中所有用户的信息&#xff0c;包括添加、删除和修改用户。 配置管理&#xff1a;管理系统配置参数&#xff0c;如上传图片的路径等。 权限管理&#xff1a;分配和管理…...

JAVA并发编程 --- 补充内容

1 线程状态 1.1 状态介绍 当线程被创建并启动以后&#xff0c;它既不是一启动就进入了执行状态&#xff0c;也不是一直处于执行状态。线程对象在不同的时期有不同的状态。那么Java中的线程存在哪几种状态呢&#xff1f;Java中的线程 状态被定义在了java.lang.Thread.State枚…...

ADB三个模块介绍

ADB&#xff08;Android Debug Bridge&#xff09;是 Android 开发中非常重要的工具&#xff0c;它由 3 个主要模块 组成&#xff0c;分别是 ADB Client&#xff08;客户端&#xff09;、ADB Server&#xff08;服务端&#xff09; 和 ADB Daemon&#xff08;守护进程&#xff…...