Centos7.9安装rabbitmq

news2024/9/30 17:29:54

1. 概述

AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。2006年,AMQP 规范发布。类比HTTP。
在这里插入图片描述

AMQP这个过程就是:由生产者发布消息到交换机,交换机再通过路由规则将消息发送到不同的队列中去存储,然后消费者从队列中监听拿走对应的消息来消费。

2007年,Rabbit 技术公司基于 AMQP 标准开发的 RabbitMQ 1.0 发布。RabbitMQ 采用 Erlang 语言开发。Erlang 语言由 Ericson 设计,专门为开发高并发和分布式系统的一种语言,在电信领域使用广泛。
Rabbitmq架构图
在这里插入图片描述

RabbitMQ概念:

Broker:接收和分发消息的应用,RabbitMQ Server就是 Message Broker
Virtual host:出于多租户和安全因素设计的,把 AMQP 的基本组件划分到一个虚拟的分组中,类似于网络中的 namespace 概念。当多个不同的用户使用同一个 RabbitMQ server 提供的服务时,可以划分出多个vhost,每个用户在自己的 vhost 创建 exchange/queue 等
Connection:publisher/consumer 和 broker 之间的 TCP 连接
Channel:如果每一次访问 RabbitMQ 都建立一个 Connection,在消息量大的时候建立TCP Connection的开销将是巨大的,效率也较低。Channel 是在 connection 内部建立的逻辑连接,如果应用程序支持多线程,通常每个thread创建单独的 channel 进行通讯,AMQP method 包含了channel id 帮助客户端和message broker 识别 channel,所以 channel 之间是完全隔离的。Channel 作为轻量级的 Connection 极大减少了操作系统建立 TCP connection 的开销
Exchange:message 到达 broker 的第一站,根据分发规则,匹配查询表中的 routing key,分发消息到queue 中去。常用的类型有:direct (point-to-point), topic (publish-subscribe) and fanout (multicast)
Queue:消息最终被送到这里等待 consumer 取走Binding:exchange 和 queue 之间的虚拟连接,binding 中可以包含routing key。Binding 信息被保存到 exchange 中的查询表中,用于 message 的分发依据

6 种工作模式:

  • 简单模式
  • work queues
  • Publish/Subscribe 发布与订阅模式
  • Routing路由模式
  • Topics 主题模式
  • RPC 远程调用模式(远程调用,不太算 MQ;暂不作介绍)
    官网对应模式介绍:https://www.rabbitmq.com/getstarted.html

2. 下载安装资源

[root@localhost software]# mkdir rabbitmq
[root@localhost software]# cd rabbitmq/
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/erlang-rpm/releases/download/v23.3.4.10/erlang-23.3.4.10-1.el7.x86_64.rpm
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.9.16/rabbitmq-server-3.9.16-1.el7.noarch.rpm
[root@localhost rabbitmq]# wget --content-disposition http://www.rpmfind.net/linux/centos/7.9.2009/os/x86_64/Packages/socat-1.7.3.2-2.el7.x86_64.rpm
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/tag/3.9.0/rabbitmq_delayed_message_exchange-3.9.0.ez
[root@localhost rabbitmq]# ls -lh
total 34M
-rw-r--r-- 1 root root  20M Dec 22  2021 erlang-23.3.4.10-1.el7.x86_64.rpm
-rw-r--r-- 1 root root 158K Mar 27 09:39 rabbitmq_delayed_message_exchange-3.9.0.ez
-rw-r--r-- 1 root root  15M Apr 27  2022 rabbitmq-server-3.9.16-1.el7.noarch.rpm
-rw-r--r-- 1 root root 290K Aug 10  2017 socat-1.7.3.2-2.el7.x86_64.rpm

3. 检查与卸载

#卸载erlang
[root@localhost rabbitmq]# yum list | grep erlang
[root@localhost rabbitmq]# find / -name erlang
/usr/lib64/erlang
[root@localhost rabbitmq]# rm -rf /usr/lib64/erlang
[root@localhost rabbitmq]# yum -y remove erlang-*
[root@localhost rabbitmq]# yum remove erlang.x86_64
#卸载rabbitmq
[root@localhost rabbitmq]# yum list | grep rabbitmq
[root@localhost rabbitmq]# yum -y remove rabbitmq-server.noarch
[root@localhost rabbitmq]# whereis rabbitmq
[root@localhost rabbitmq]# rm -rf /usr/lib/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/rabbitmq
[root@localhost rabbitmq]# find / -name rabbitmq
[root@localhost rabbitmq]# rm -rf /var/lib/rabbitmq
[root@localhost rabbitmq]# rm -rf /var/log/rabbitmq
[root@localhost rabbitmq]# rm -rf /run/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/selinux/targeted/active/modules/100/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/selinux/targeted/tmp/modules/100/rabbitmq
#安装编译环境
[root@localhost rabbitmq]# yum -y install build-essential openssl openssl-devel unixODBC unixODBC-devel make gcc gcc-c++ kernel-devel m4 ncurses-devel tk tc xz
#安装erlang
[root@localhost rabbitmq]# rpm -ivh erlang-23.3.4.10-1.el7.x86_64.rpm
[root@localhost rabbitmq]# erl -version
Erlang (SMP,ASYNC_THREADS,HIPE) (BEAM) emulator version 11.2.2.9
#安装socat
[root@localhost rabbitmq]# rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
#安装rabbitmq
[root@localhost rabbitmq]# rpm -ivh rabbitmq-server-3.9.16-1.el7.noarch.rpm
[root@localhost rabbitmq]# rpm -qa | grep rabbitmq
#安装rabbitmq_delayed延时队列插件
[root@localhost rabbitmq]# cp rabbitmq_delayed_message_exchange-3.9.0.ez /usr/lib/rabbitmq/lib/rabbitmq_server-3.9.16/plugins
[root@localhost rabbitmq]# cd /usr/lib/rabbitmq/lib/rabbitmq_server-3.9.16/plugins
[root@localhost plugins]# rabbitmq-plugins enable rabbitmq_delayed_message_exchange
#rabbitmq服务[启动|停止|重启|状态|自启]
[root@localhost plugins]# vi /etc/hosts
添加 127.0.0.1 mail
[root@localhost plugins]# systemctl start rabbitmq-server
[root@localhost plugins]# journalctl -u rabbitmq-server
[root@localhost plugins]# systemctl [start|stop|restart|status|enable] rabbitmq-server
#创建相关账户
[root@localhost plugins]# rabbitmqctl add_user ubox *********
[root@localhost plugins]# rabbitmqctl set_user_tags ubox administrator
[root@localhost plugins]# rabbitmqctl set_permissions -p "/" ubox ".*" ".*" ".*"
[root@localhost plugins]# rabbitmqctl add_vhost ubox
[root@localhost plugins]# rabbitmqctl list_vhosts
[root@localhost plugins]# rabbitmqctl list_users
#其他命令行
#添加用户
rabbitmqctl add_user 用户名 密码
#删除用户
rabbitmqctl  delete_user  用户名
#修改用户密码
rabbitmqctl  change_password  用户名  新密码
#查看用户列表
rabbitmqctl  list_users
#分配用户角色
rabbitmqctl set_user_tags ubox administrator
#添加虚拟机
rabbitmqctl add_vhost xxx
#删除虚拟机
rabbitmqctl delete_vhost xxx
#查看虚拟机列表
#rabbitmqctl list_vhosts
#分配用户具体权限 
rabbitmqctl set_permissions -p / 用户名 ".*" ".*" ".*"
#清除用户权限
rabbitmqctl  clear_permissions  [-p VHostPath]  User
#先查看所有开放的端口号
sudo firewall-cmd --zone=public --list-ports
#开放15672和5672端口
iptables -I INPUT -p tcp --dport 5672 -j ACCEPT
iptables -I INPUT -p tcp --dport 15672 -j ACCEPT
#重载使上述命令生效
firewall-cmd --reload

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1614237.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Jackson知识点记录

文章目录 一.Jackson模块说明 二.ObjectMapper基本功能使用ObjectMapper的一些核心方法:示例代码1. 序列化示例2. 反序列化示例3. JsonNode 处理示例 高级配置 三.各种Node1. ObjectNode2. ArrayNode3. ValueNode4. MissingNode示例 一.Jackson Jackson 库主要分为…

安泰电子 :高压功率放大器设计方案有哪些

高压功率放大器是现代通信和电子设备中不可或缺的关键组件。它能够将低功率信号放大到足够的功率水平,以便在各种应用中实现远距离传输和覆盖范围。下面西安安泰电子将介绍高压功率放大器的设计方案,包括电路拓扑、元件选择、功率损耗和失真控制等方面的…

vue3的getCurrentInstance获取当前组件实例

vue3的setup中没有this时需要使用getCurrentInstance()来获取。 在 Vue 3 中,getCurrentInstance 方法可以在组合式 API(Composition API)中获取当前组件实例。这个方法返回一个包含了组件实例的对象,你可以用它来访问组件的 pro…

Apache POI报表统计

Apache POl是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是&#xff0c;我们可以使用 POl 在 Java 程N序中对Miscrosoft Office各种文件进行读写操作。一般情况下&#xff0c;POI都是用于操作 Excel 文件。 导入Maven坐标&#xff1a; <dependency>&l…

文件I/O基础-I.MX6U嵌入式Linux C应用编程学习笔记基于正点原子阿尔法开发板

本章将介绍Linux应用编程中最基础的知识&#xff0c;即文件I/O&#xff08;Input/Output&#xff09;。文件I/O指的是对文件进行读写操作&#xff0c;在Linux系统中一切皆文件&#xff0c;这是Linux系统设计的核心理念&#xff0c;因此文件I/O操作既是基础又是最重要的部分。本…

剑指offer剪绳子;leetcode:LCR 131. 砍竹子 I

现需要将一根长为正整数 bamboo_len 的竹子砍为若干段&#xff0c;每段长度均为正整数。请返回每段竹子长度的最大乘积是多少。 示例 1&#xff1a; 输入: bamboo_len 12 输出: 81提示&#xff1a; 2 < bamboo_len < 58 注意&#xff1a;本题与主站 343 题相同&#…

硬件中断错误HardFault_Handle如何解决

一、在硬件中断处点击断点 二、打开Call Stack Window 三、打开Disassembly Window 四、右击空白处&#xff0c;输入遇到硬件中断前地址&#xff0c;即可知道错误原因 程序就会自动跳转硬件中断错误处 ​​​​​​

Python中列表数据的保存与读取:以txt文件为例

目录 引言 一、列表数据的保存 二、列表数据的读取 三、进阶用法与注意事项 1. 处理嵌套列表 2. 处理大量数据 3. 注意事项 四、总结 引言 在Python编程中&#xff0c;我们经常需要处理各种类型的数据&#xff0c;包括列表。列表是一种非常灵活的数据结构&#xff0c;…

天梯赛 L2-052 吉利矩阵

//r[n]:当前第几列的值。 //l[n]:当前第几行的值。 暴力减止 #include<bits/stdc.h> using namespace std; #define int long long const int n1e3; int a,b,c,l[n],r[n],an; void dfs(int x,int y) {if(xb1){an;return ;}for(int i0;i<a;i){l[x]i;r[y]i;if(l[x]&l…

Gateway断言工厂

这个用的时候可以在官网上查

0.5W 3KVDC 隔离单、双输出 DC/DC 电源模块——TPV-W5 3.3V, 5V,12V 15V系列

TPV-W5系列提供正负双输出和单输出&#xff0c;工业级环境温度&#xff0c;用于PCB安装的国际标准结构。此系列产品小巧&#xff0c;效率高&#xff0c;低输出纹波及能承受3000V以上的耐压&#xff0c;用于需要正负电压或单输出和高隔离电压的场合。封装有SIP和DIP可选。

第一届 “帕鲁杯“ writeup

文章目录 MiscMisc-签到江FM 145.8ez_misc为什么我的新猫猫吃不饱 Crypto玛卡巴卡有什么坏心思呢 webWeb-签到 应急响应1.找到JumpServer堡垒机中flag标签的值。2.提交攻击者第一次登录时间。3.提交攻击者源IP。4.提交攻者使用的cve编号。5.提交攻击者留在Web服务器上的恶意程序…

Linux系统-进程和计划任务管理

一.程序和进程 1.程序 保持在硬盘、光盘等介质中的可执行代码和数据文件中静态保存的代码 2.进程 在CPU及内存中运行的程序代码动态执行的代码父、子进程每个程序可以创建一个或多个进程 3.进程特征 动态性&#xff1a;进程是程序的一次执行过程&#xff0c;是临时的&…

使用easyexcel将csv转为excel

一.背景 供应商系统下载的csv文件不支持域控&#xff08;主要是第三方wps服务不能对csv文件加密&#xff0c;但是可以对office系列产品进行权限访问的加密控制&#xff09;。因此思路就改为现将csv文件转为excel文件&#xff0c;然后对excel文件进行加域控制。本文主要介绍如何…

MySQL学习笔记5——函数和索引

函数和索引 一、函数1、数学函数2、字符串函数3、条件判断函数 二、索引1、索引是什么2、单字段索引3、组合索引4、总结 一、函数 MySQL提供了很多功能强大&#xff0c;而且使用起来非常方便的函数&#xff0c;包括数学函数、字符串处理函数和条件判断函数等。 1、数学函数 …

Flink面试(1)

1.Flink 的并行度的怎么设置的&#xff1f; Flink设置并行度的几种方式 1.代码中设置setParallelism() 全局设置&#xff1a; 1 env.setParallelism(3);  算子设置&#xff08;部分设置&#xff09;&#xff1a; 1 sum(1).setParallelism(3) 2.客户端CLI设置&#xff0…

shell简单联系项目

文章目录 推荐一个vscode上的好用的神奇如何使用的方式连接主机的方式配置新主机配置信息启动连接的方式 联系shell 命令的方式读取文件信息设置本地环境变量的方式获取随机数的方式简单案例信息 推荐一个vscode上的好用的神奇 如何使用的方式 连接主机的方式 配置新主机 配置…

运维小技能:nacos部署(外接mysql)

文章目录 I 安装nacos(m1版本)1.1 镜像启动1.2 查看docker容器日志1.3 开启鉴权II 外接mysql的docker部署方式2.1 复制mysql-schema.sql2.2 导入mysql-schema.sqlIII 配置远程用户3.1 创建数据库远程用户3.2 查看远程用户是否有密码I 安装nacos(m1版本) docker search nacos:查…

集成触发器(数电笔记)

同步触发器&#xff1a; 主从触发器&#xff1a; 边沿触发器&#xff1a;

【团体程序设计天梯赛】L2-052 吉利矩阵

思路&#xff1a; 直接回溯枚举每一个位置填的数&#xff0c;二维肯定是不方便的&#xff0c;我们转成一维&#xff0c;下标x从0到n*n-1。二维数组下标从0到n-1&#xff0c;在一维中下标为x的点在二维中对应行是x/n&#xff0c;列是x%n。 每个数最小能填的是0&#xff0c;最大…