环境搭建---部署rabbitmq集群

news2024/9/23 17:22:05

rabbitmq下载:https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.34/rabbitmq-server-generic-unix-3.8.34.tar.xz
erlang下载:https://github.com/erlang/otp/releases/download/OTP-24.3.4.1/otp_src_24.3.4.1.tar.gz

配置主机名

[root@zhcs-cvm-01]# hostnamectl set-hostname zhcs-cvm-01
[root@zhcs-cvm-01]# hostname zhcs-cvm-01
[root@zhcs-cvm-02]# hostnamectl set-hostname zhcs-cvm-02
[root@zhcs-cvm-02]# hostname zhcs-cvm-02
[root@zhcs-cvm-03]# hostnamectl set-hostname zhcs-cvm-03
[root@zhcs-cvm-03]# hostname zhcs-cvm-03

配置hosts文件

[root@zhcs-cvm-01 sbin]# cat /etc/hosts
10.206.0.44 zhcs-cvm-01
10.206.0.45 zhcs-cvm-02
10.206.1.46 zhcs-cvm-03
[root@zhcs-cvm-02 sbin]# cat /etc/hosts
10.206.0.44 zhcs-cvm-01
10.206.0.45 zhcs-cvm-02
10.206.1.46 zhcs-cvm-03
[root@zhcs-cvm-03 sbin]# cat /etc/hosts
10.206.0.44 zhcs-cvm-01
10.206.0.45 zhcs-cvm-02
10.206.1.46 zhcs-cvm-03

配置免密登陆:(三台均配置)

[root@zhcs-cvm-01]# ssh-keygen -t rsa
[root@zhcs-cvm-01]# cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys
[root@zhcs-cvm-01]# ssh-copy-id -i /root/.ssh/id_rsa.pub root@zhcs-cvm-02
[root@zhcs-cvm-01]# ssh-copy-id -i /root/.ssh/id_rsa.pub root@zhcs-cvm-03

安装erlang:

[root@zhcs-cvm-01]# tar -xf otp_src_24.3.4.1.tar.gz
[root@zhcs-cvm-01]# cd otp_src_24.3.4.1/
[root@zhcs-cvm-01]# ./configure --prefix=/opt/erlang
[root@zhcs-cvm-01]# make && make install
[root@zhcs-cvm-01]# vim /etc/profile
ERL_HOME=/opt/erlang
PATH=$ERL_HOME/bin:$PATH
export ERL_HOME PATH
[root@zhcs-cvm-01]# source /etc/profile

同步cookie文件

[root@zhcs-cvm-01]# scp /root/.erlang.cookie root@zhcs-cvm-02:/root/.erlang.cookie 
[root@zhcs-cvm-01]# scp /root/.erlang.cookie root@zhcs-cvm-03:/root/.erlang.cookie 

安装rabbitmq:

三台均操作:

[root@zhcs-cvm-01]# tar -xf rabbitmq-server-generic-unix-3.8.34.tar.xz
[root@zhcs-cvm-01]# cd rabbitmq_server-3.8.34
[root@zhcs-cvm-01]# ./sbin/rabbitmq-plugins enable rabbitmq_management
[root@zhcs-cvm-01]# ./sbin/rabbitmq-server -detached

只在其他节点操作:

[root@zhcs-cvm-01 sbin]# ./rabbitmqctl stop_app
[root@zhcs-cvm-01 sbin]# ./rabbitmqctl reset
[root@zhcs-cvm-01 sbin]# ./rabbitmqctl join_cluster rabbit@zhcs-cvm-01
[root@zhcs-cvm-01 sbin]# ./rabbitmqctl start_app

创建用户授权

[root@zhcs-cvm-01 sbin]# ./rabbitmqctl add_user admin password
[root@zhcs-cvm-01 sbin]# ./rabbitmqctl set_permissions -p / admin ".*" ".*" ".*"
[root@zhcs-cvm-01 sbin]# ./rabbitmqctl set_user_tags admin administrator
rabbitmqctl set_permissions --vhost   

虚拟主机 用户名 “对哪些实体有配置权限” “对哪些实体有写权限” “对哪些实体有读权限”

rabbitmqctl set_permissions --vhost "/" fkjava ".*" ".*" ".*"

查看集群状态

[root@zhcs-cvm-01 sbin]#./rabbitmqctl cluster_status
Cluster status of node rabbit@zhcs-cvm-01 ...
Basics

Cluster name: rabbit@zhcs-cvm-01

Disk Nodes

rabbit@zhcs-cvm-01
rabbit@zhcs-cvm-02
rabbit@zhcs-cvm-03

Running Nodes

rabbit@zhcs-cvm-01
rabbit@zhcs-cvm-02
rabbit@zhcs-cvm-03

Versions

rabbit@zhcs-cvm-01: RabbitMQ 3.8.34 on Erlang 24.3.4.1
rabbit@zhcs-cvm-02: RabbitMQ 3.8.34 on Erlang 24.3.4.1
rabbit@zhcs-cvm-03: RabbitMQ 3.8.34 on Erlang 24.3.4.1

Maintenance status

Node: rabbit@zhcs-cvm-01, status: not under maintenance
Node: rabbit@zhcs-cvm-02, status: not under maintenance
Node: rabbit@zhcs-cvm-03, status: not under maintenance

Alarms

(none)

Network Partitions

(none)

Listeners

Node: rabbit@zhcs-cvm-01, interface: [::], port: 15672, protocol: http, purpose: HTTP API
Node: rabbit@zhcs-cvm-01, interface: [::], port: 25672, protocol: clustering, purpose: inter-node and CLI tool communication
Node: rabbit@zhcs-cvm-01, interface: [::], port: 5672, protocol: amqp, purpose: AMQP 0-9-1 and AMQP 1.0
Node: rabbit@zhcs-cvm-02, interface: [::], port: 15672, protocol: http, purpose: HTTP API
Node: rabbit@zhcs-cvm-02, interface: [::], port: 25672, protocol: clustering, purpose: inter-node and CLI tool communication
Node: rabbit@zhcs-cvm-02, interface: [::], port: 5672, protocol: amqp, purpose: AMQP 0-9-1 and AMQP 1.0
Node: rabbit@zhcs-cvm-03, interface: [::], port: 15672, protocol: http, purpose: HTTP API
Node: rabbit@zhcs-cvm-03, interface: [::], port: 25672, protocol: clustering, purpose: inter-node and CLI tool communication
Node: rabbit@zhcs-cvm-03, interface: [::], port: 5672, protocol: amqp, purpose: AMQP 0-9-1 and AMQP 1.0

Feature flags

Flag: drop_unroutable_metric, state: enabled
Flag: empty_basic_get_metric, state: enabled
Flag: implicit_default_bindings, state: enabled
Flag: maintenance_mode_status, state: enabled
Flag: quorum_queue, state: enabled
Flag: user_limits, state: enabled
Flag: virtual_host_metadata, state: enabled

在这里插入图片描述

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

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

相关文章

MySQL原理之UUID主键分析,插入或更新语法分析

文章目录 1 MySQL不能用UUID做主键1.1 前言1.2 mysql和程序实例1.2.1 准备工作1.2.2 开始测试1.2.3 程序写入结果1.2.4 效率测试结果 1.3 使用uuid和自增id的索引结构对比1.3.1 自增id1.3.2 uuid 1.4 自增id缺点1.5 雪花算法 2 插入或更新2.1 on duplicate key2.1.1 定义2.1.2 …

git版本问题Your branch is behind ‘origin/dev‘by 2 commits,

git版本问题 一个不小心点击了版本的修改,于是就进入了翻滚中,回不来了 遇事还是不要慌,出现这个问题,如果那些你不需要,只是需要回到某一个版本,那么就是需要 git reset --hard origin/master 上面这就…

Vue3入门 - 登录功能开发(Vue3+ts+Pinia+Element Plus)

Vue3中实现登录功能,通常涉及到创建一个表单,用户输入用户名和密码,然后将信息发送到后端进行验证,得到响应结果后作出相应操作。 一、创建项目 这里他用pnpm进行项目的创建的,所以需要事先全局安装pnpm(在…

神经网络的非线性激活

文章目录 一、神经网络的非线性激活是什么二、非线性激活常用函数三、非线性激活的实际演示 一、神经网络的非线性激活是什么 神经网络的非线性激活函数的主要作用是引入非线性变换,从而使网络能够学习和逼近复杂的函数关系。在神经网络中,线性变换&…

[产品管理-4]:NPDP新产品开发 - 2 - 战略 - 制定企业经营战略目标的结构化方法与工具

目录 一、SWOT分析工具 1、SWOT分析工具概述 2、SWOT分析与企业战略目标制定的关系 3、SWOT分析在企业战略目标制定中的应用实例 4、SWOT分析的改进与应用建议 二、P E S T L E 分 析:外部环境分析 2.1 概述 1. 政治因素(Political) …

COCOS:(飞机大战08)子弹和飞机添加碰撞器和刚体

做两个物体的碰撞有2种方式:碰撞检测和触发检测 这里子弹不能和飞机使用碰撞检测,因为会影响到敌机的运动,所有选择使用触发检测 从预制体Prefabs文件中,将子弹Bullet1和Bullet2拖到Canvas下 选中子弹,添加组件&#…

多线程:java中的实现

实现1: 通过java.util.concurrent.atomic中的原子性数据实现 static class Counter {// 通过加锁实现同步public static int count 0;public static final Object obj new Object(); // 通过原子性的整型来实现同步public static AtomicInteger c…

DesignPattern设计模式

1 前言 1.1 内容概要 理解使用设计模式的目的掌握软件设计的SOLID原则理解单例的思想,并且能够设计一个单例理解工厂设计模式的思想,能够设计简单工厂,理解工厂方法了解建造者模式的思想,掌握其代码风格理解代理设计模式的思想&a…

应用层自定义协议与序列化

一、理解应用层 上一篇文章http://t.csdnimg.cn/931k6简单介绍了如何写tcp / udp 网络服务,但是其实始终是在应用层。 一个个解决我们实际问题, 满足我们日常需求的网络程序, 都是在应用层。 二、再谈协议 协议是一种 "约定"。socket api 的接口, 在读…

TiDB从0到1学习笔记(精华篇)

历时四个月,恭喜赵老师的《TiDB从0到1》 系列文章顺利完结,小编再次梳理一遍文稿,并附注解分享给大家。 整体架构 从 TiDB 1.0 到 8.0,TiDB 的体系结构一直在不断演进。接下来让我们一起看看整体架构的变化。 TiDB v1 TiDB v1&…

005——栈

目录 栈 栈的定义 栈的性质 栈的应用场景 存储结构: Ⅰ)采用顺序存储结构实现——顺序栈 Ⅱ)采用链式存储结构实现——链栈-->基于单链表(带头结点) 栈 栈的定义 之允许在一端进行插入和删除的线性表 栈的…

安卓获取apk的公钥,用于申请app备案等

要申请app的icp备案等场景,需要app的 证书MD5指纹和公钥,示例如下: 步骤1:使用keytool从APK中提取证书 1. 打开命令行,cd 到你的apk目录,如:app/release 2. 解压APK文件: unzip yo…

一维稳态与非稳态导热的详细分析

目录 引言 一维稳态导热 应用实例:单层平壁导热 数值求解: 一维非稳态导热 应用实例:单层平壁的非稳态导热 温度变化阶段 表格总结: 引言 热传导(Heat Conduction)是热量在物体内部通过微观粒子的相…

批量从word切割说话人!!对于转录后的文本进行纯数据清洗切割和区分说话人-批量从word切割说话人

battle AI的全过程 文章目录 初步切割同时基于文本中提取的动词变化类别做切割以及发言人变化路径设置 迁移模型到GPUbert输出空白debugCPU能运行的语义相似度代码GPU能用了但是没有加切分规则的代码 根据动词变化切分把发言人替换老师和学生的代码读取txt的代码先区分说话人&a…

Qt常用控件——QLCDNumber

文章目录 QLCDNumber核心属性倒计时小程序倒计时小程序相关问题 QLCDNumber核心属性 QLCDNumber是专门用来显示数字的控件,类似于这样: 属性说明intValue获取的数字值(int).value获取的数字值(double)和intValue是联动的例如value设为1.5,in…

黑马点评22——最佳实践-批处理优化

文章目录 pipeline和mset集群模式下的批处理问题 pipeline和mset pipeline就是大数据量的导入,pipeline是在单机模式下的。 redis的处理耗时相比较网络传输的耗时其实是比较低的。 所以我们最好采用批处理, 集群模式下的批处理问题 在集群环境…

生动灵活,MegActor重磅升级!旷视科技发布MegActor-Σ:首个基于DiT的人像动画方法!

文章链接:https://arxiv.org/pdf/2408.14975 项目链接:https://megactor-ops.github.io/ 亮点直击 一种新颖的混合模态扩散Transformer(DiT),能够有效整合音频和视觉控制信号。相较于之前基于UNet的方法,这…

qsort的理解--加强对指针的理解

前言:前面我们学习指针变量,数组指针变量,函数指针变量;这些实际上都是变量,实质上是在内存中开辟一块空间;而这些变量存储的都是地址。还有指针数组,函数指针数组,这指的是把多个地…

AIGC大模型扩图:Sanster/IOPaint(4)

AIGC大模型扩图:Sanster/IOPaint(4) 用大模型实现AI扩大一张图的周边区域,变得更大,当然必须契合原图,和原图浑然一体。 1、这次模型换用 Sanster/PowerPaint-V1-stable-diffusion-inpainting 启动&#xf…

文件对比工具--BeyondCompare

💖简介 Beyond Compare 是一款功能强大的文件和文件夹比较工具,由Scooter Software开发。它可以帮助用户轻松地比较文件和文件夹的差异,并且可以合并变化、同步文件以及备份重要数据 💻环境 windows 📖版本 Beyon…