Centos7单节点部署RabbitMQ

Centos7单节点部署RabbitMQ

简介

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

历史

Rabbit科技有限公司开发了RabbitMQ,并提供对其的支持。起初,Rabbit科技是LSHIFT和CohesiveFT在2007年成立的合资企业,2010年4月被VMware旗下的SpringSource收购。RabbitMQ在2013年5月成为GoPivotal的一部分。

基本概念

RabbitMQ是一套开源(MPL)的消息队列服务软件,是由 LShift 提供的一个 Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能、健壮以及可伸缩性出名的 Erlang 写成。
RabbitMQ服务支持下列操作系统:
Linux 、WindowsNT 到 10 Windows、 Server2003 到 2016、 macOS、 Solaris、 FreeBSD 、 TRU64、 VxWorks
RabbitMQ支持下列编程语言:
Python、 Java 、Ruby、 PHP、 C# 、JavaScript 、Go、 Elixir、 Objective-C 、Swift

主要特性

可伸缩性:集群服务
消息持久化:从内存持久化消息到硬盘,再从硬盘加载到内存

安装

Erlang与RabbitMQ,安装路径都应不含空格符。
Erlang使用了环境变量HOMEDRIVE与HOMEPATH来访问配置文件.erlang.cookie,应注意这两个环境变量的有效性。需要设定环境变量ERLANG_HOME,并把%ERLANG_HOME%\bin加入到全局路径中。
RabbitMQ使用本地computer name作为服务器的地址,因此需要注意其有效性,或者直接解析为127.0.0.1
可能需要在本地网络防火墙打开相应的端口。

在这里插入图片描述

AMQP:高级消息队列协议,是应用协议开放的标准,为面向消息中间件设计,它可以使用客户端和对应消息队列进行交互,消息中间件从发布者哪里接收消息,然后转发给消费者(处理消息的应用)。

消息列队: 处理的事件: 流量消峰:秒杀的过程中,常用消息队列来防止后端服务器宕机, 异步处理:数据模型 架构解耦:

消息队列的种类: Redis:后端数据消息队列 MemcacheQ:完美兼容 memcache 多台队列 并发性能好
MSMQ:消息最大的载体,4M,只有发送和接收功能 ZeroMQ:号称最快的消息队列,高吞吐,低延迟,在金融方面用的比较多
Kafka:支持快速的持久化,异步收取,数据量大,高吞吐 ActiveMQ:java的中间力量。
RabbitMQ:开源的,最早的消息队列,最稳定,速度慢,扩展性能比较差,消息封装之后比较大。

RabbitMQ:
在这里插入图片描述

Rabbitmq server,消息队列服务,用于接收生产者产生的消息,并将消息分配给消费者
Producer 生产者,生产消息,消息分为两个部分。 标签和数据,标签用于交换匹配

Consumer 消费者,用来消费队列分配的消息,处理完之后要给队列发送ack回应。
消息ack机制:用来判断哪些消息被消费了,如果检测到被消费了,那么这个消息就会被删除,如果所有的consumer没有消费,这个消息就会回转,再次等带消费。

Connection 生产者和消费者与消息队列的tcp连接
Channel 虚拟通道,建立在tcp之上。
Exchange 交换机,会根据自身的匹配规则交给合适的queue
Exchange的匹配规则:
# Fanout 生产者发送过来的消息交给所有的对列
# Direct 进行精准匹配
# Topic 进行模糊匹配
Queue 消息的载体,队列
Vhost 虚拟主机,一个vhost相当于一个rabbit server ,有单独的队列和交换机。

集群模式:
普通模式:将生产者的消息放在单独的节点上。
镜像模式:将生产者的消息存放在多个节点上。
镜像模式的三个选项:
# all 将产生的消息放在所有的节点上。
# Exactly 将产生的消息放在指定数量的节点上。
# Nodes 将产生的消息放在指定的节点上。


单节点部署RabbitMQ

环境准备

IP 版本 服务
192.168.1.40 CentOS Linux release 7.6.1810 (Core) rabbitmq-server(3.6.15)、erlang(18.1)

RabbitMQ、Erlang安装包链接?

链接:https://pan.baidu.com/s/18ICeCho2kYajfH6lL1xa7w 
提取码:8z7v 
复制这段内容后打开百度网盘手机App,操作更方便哦

安装基本命令

[root@localhost ~]# yum -y install vim net-tools lrzsz net-tools mkae cmake gcc-c++

安装RabbitMQ、Erlang

[root@localhost ~]# rpm -ivh erlang-18.1-1.el7.centos.x86_64.rpm 
准备中...                          ################################# [100%]
正在升级/安装...
   1:erlang-18.1-1.el7.centos         ################################# [100%]
[root@localhost ~]# yum -y install socat
[root@localhost ~]# rpm -ivh rabbitmq-server-3.6.15-1.el7.noarch.rpm 
警告:rabbitmq-server-3.6.15-1.el7.noarch.rpm: 头V4 RSA/SHA1 Signature, 密钥 ID 6026dfca: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:rabbitmq-server-3.6.15-1.el7     ################################# [100%]

启动服务

[root@localhost ~]# systemctl start rabbitmq-server

查看状态

[root@localhost ~]# rabbitmqctl cluster_status
Cluster status of node rabbit@localhost
[{
   nodes,[{
   disc,[rabbit@localhost]}]},
 {
   running_nodes,[rabbit@localhost]},
 {
   cluster_name,<<"rabbit@localhost">>},
 {
   partitions,[]},
 {
   alarms,[{
   rabbit@localhost,[]}]}]

关闭防火墙、沙盒

[root@localhost ~]# systemctl stop firewalld && systemctl disable firewalld && setenforce 0
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

添加插件

[root@localhost ~]# rabbitmq-plugins enable rabbitmq_management
The following plugins have been enabled:
  amqp_client
  cowlib
  cowboy
  rabbitmq_web_dispatch
  rabbitmq_management_agent
  rabbitmq_management

Applying plugin configuration to rabbit@localhost... started 6 plugins.

添加当前登陆的用户,并将这个用户设为管理员

[root@localhost ~]# rabbitmqctl delete_user guest
Deleting user "guest"
[root@localhost ~]# rabbitmqctl add_user test 123.com
Creating user "test"
[root@localhost ~]# rabbitmqctl set_user_tags test administrator
Setting tags for user "test" to [administrator]

访问

http://192.168.1.40:15672/

在这里插入图片描述
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101931.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 看这里!2021年Java开发突破20k有哪些有效的路径?绝对干货[通俗易懂]

    看这里!2021年Java开发突破20k有哪些有效的路径?绝对干货[通俗易懂]前言微服务是近年来备受关注的话题,相比于传统的SOA而言,更容易理解,也更容易实践,它将“面向服务”的思想做得更加彻底。有人说它非常好,但就是“玩不起”,why?微服务是一种分布式系统架构,它建议我们将业务切分为更加细粒度的服务,并使每个服务的责任单一且可独立部署,服务内部高内聚,隐含内部细节,服务之间低耦合,彼此相互隔离。此外,我们根据面向服务的业务领域来建模,对外提供统一的API接口。微服务的思想不只是停留在开发阶段,它贯穿于设计、开发、测试、部署、运维等软件生命周期阶段。可见,我们提到的微服务,

    2022年7月8日
    19
  • 用GVIM/VIM写Verilog——VIM配置分享「建议收藏」

    用GVIM/VIM写Verilog——VIM配置分享「建议收藏」使用VIM或GVIM最基本的配置,不包含任何插件相关的设置,VIM用于写verilog,非常欢迎大家在评论区分享讨论。本文不进行插件的配置,不进行基本使用方式与使用技巧的说明,仅作为基本配置的分享交流用GVIM/VIM写Verilog——VIM配置分享基本配置几点说明1,禁用方向键,使用jk代替ESC2,自动补全命令配置3,进行版权声明的设置4,一些其他映射基本配置setnocompatible”不兼容visyntaxon”语法高亮度显示setnoerrorbells”.

    2022年9月30日
    6
  • pycharm配置Git和Github[通俗易懂]

    pycharm配置Git和Github[通俗易懂](Windows)pycharm配置Git和Github,协同开发1、安装Git1.1、验证是否安装git#cmd命令git–version#显示git版本则证明安装成功1.2、下载gitwindow下载链接安装好git之后,配置环境变量,验证git是否安装成功。1.3、配置git用户名和邮箱gitconfig–globaluser.name用户名gitconfig–globaluser.email邮箱1.4、在pycharm中配置git点击Fil

    2022年8月26日
    11
  • XFF漏洞利用[通俗易懂]

    XFF漏洞利用[通俗易懂]作者:小刚一位苦于信息安全的萌新小白帽,记得关注给个赞,谢谢本实验仅用于信息防御教学,切勿用于其它用途XFF漏洞X-Forwarded-For(XFF)利用方式1.绕过服务器过滤2.XFF导致sql注入补充X-Forwarded-For(XFF)XFF是header请求头中的一个参数是用来识别通过HTTP代理或负载均衡方式连接到Web服务器的客户端最原始的IP地址的HTTP请求头字段。代表了HTTP的请求端真实的IP。X-Forwarded-For:client1,proxy1,p.

    2022年6月16日
    62
  • 奥迪token失效,请重新登录_请求token失效怎么解决

    奥迪token失效,请重新登录_请求token失效怎么解决出现Token失效,请重新登录重新登录下就好了啊1首先我们的先拿到token2.放上Authorize再去测试自己的接口这样就好了

    2025年8月31日
    15
  • 揭秘分析:朋友圈集赞引流套路,老用户是如何带来裂变效果?[通俗易懂]

    揭秘分析:朋友圈集赞引流套路,老用户是如何带来裂变效果?[通俗易懂]微信总裁张小龙在”2021年微信公开课PRO”演讲中表示:每天都有10.9亿用户打开微信。3.3亿用户进行视频通话,7.8亿用户进入朋友圈,1.2亿用户发表朋友圈。微信的用户如此庞大,朋友圈又是最大的流量洼池,企业商家想想都会”流口水”,也就理所当然成为兵家必争广告之地。  那么,怎样才能从朋友圈获得流量?小编不得不提一个大家都知道的玩法,那就是集赞。集赞可以帮助的大家找到朋友圈引流的运营之本。  朋友圈集赞运营逻辑就是老用户带动新用户,这个看上去似乎跟其他裂变玩法没有什么区别,但是还是非常值得剖析。

    2025年9月18日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号