【rabbitMQ】CentOS7.x上rabbitMQ单机的安装配置

一、RabbitMQ简介


MQ全称为Message Queue, 是一种分布式应用程序的的通信方法,它是消费-生产者模型的一个典型的代表,producer往消息队列中不断写入消息,而另一端consumer则可以读取或者订阅队列中的消息。

RabbitMQ是MQ产品的典型代表,是一款由Erlang语言开发,基于AMQP协议可复用的企业消息系统。业务上,可以实现服务提供者和消费者之间的数据解耦,提供高可用性的消息传输机制,在实际生产中应用相当广泛。


AMQP:Advanced Message Queue,高级消息队列协议。他是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产品、开发语言等条件的限制。

rabbitMQ的两个核心组件是exchange和queue

运行原理如下图:


RabbitMQ 最初起源于金融系统,用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。具体特点包括:

二、实验环境


系统操作: CentOS7.5 Mininal

IP : 192.168.1.103


三、安装rabbitMQ


添加erlang官方仓库

#  vim  /etc/yum.repos.d/rabbitmq_erlang.repo

##################################################

[rabbitmq_erlang]

name=rabbitmq_erlang

baseurl=https://packagecloud.io/rabbitmq/erlang/el/7/$basearch

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_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官方仓库

# rpm --import https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc


#  vim /etc/yum.repos.d/rabbitmq.repo

###########################################################

[bintray-rabbitmq-server]

name=bintray-rabbitmq-rpm

baseurl=https://dl.bintray.com/rabbitmq/rpm/rabbitmq-server/v3.7.x/el/7/

gpgcheck=0

repo_gpgcheck=0

enabled=1

############################################################

# yum clean all

# yum repolist  


# yum list erlang --showduplicates| sort -r

# yum list rabbitmq-server --showduplicates| sort -r


# yum  -y install epel-release 

# yum -y install  erlang  socat logrotate

# yum  -y install rabbitmq-server-3.7.10


# rpm -ql  rabbitmq-server  

# rpm -qc rabbitmq-server


启动rabbitMQ

# systemctl start rabbitmq-server

# systemctl enable rabbitmq-server

# systemctl status rabbitmq-server

# cat /etc/passwd

#  head -n 20  /var/log/rabbitmq/rabbit@`hostname`.log

# ll -a /var/lib/rabbitmq/

# cat /var/lib/rabbitmq/.erlang.cookie




# ps aux | grep rabbitmq


开启网页管理界面

# rabbitmq-plugins enable rabbitmq_management

# ss -tan | grep 5672


RabbitMQ默认监听端口:

4369   erlang发现端口

5672    client端和server端通信端口

15672  管理界面端口

25672  server间内部通信口


#  vim /usr/lib/rabbitmq/lib/rabbitmq_server-3.7.10/ebin/rabbit.app

将 {loopback_users, [<<"guest">>]},改为:{loopback_users, []},

原因:rabbitmq从3.3.0开始禁止使用guest/guest权限通过除localhost外的访问

#  systemctl restart rabbitmq-server


关闭防火墙

# systemctl stop firewalld 

# systemctl disable firewalld 


浏览器访问  http://192.168.1.103:15672

默认管理员用户名密码 : guest/guest


四、rabbitMQ命令行操作

学习rabbitmq,原理之后第一个要掌握的就是rabbitmqctl这个命令的用法了,rabbitmq的管理功能最全的就是rabbitmqctl命令,当然还有HTTP API和UI两种管理手段。

# rabbitmqctl --help

# rabbitmqctl status


rabbitMQ 用户与权限



添加用户并授权

#   rabbitmqctl add_user admin  Admin@123

#   rabbitmqctl  set_user_tags admin  administrator

#  rabbitmqctl set_permissions   -p  "/"  admin  '.*'   '.*'    '.*'

# rabbitmqctl list_users

# rabbitmqctl   list_user_permissions  admin 




# rabbitmqctl add_vhost "/test"

# rabbitmqctl add_user test Test@123

# rabbitmqctl set_user_tags test administrator

# rabbitmqctl set_permissions -p "/test" test '.*' '.*' '.*'

# rabbitmqctl list_users

# rabbitmqctl list_user_permissions test

# rabbitmqctl list_permissions -p "/test"


配置用户远程访问


# vim /etc/rabbitmq/rabbitmq.config

###########################################################################

[

{rabbit, [{tcp_listeners, [5672]}, {loopback_users, ["admin"]}]}

].


#############################################################################


# systemctl restart rabbitmq-server


浏览器访问:http://192.168.1.103:15672

admin/Admin@123



五、rabbitMQ配置文件


简单的rabbitMQ应用配置可无需配置文件,只有需要定制复杂应用时,才需要用到配置文件。

如果是用rpm包安装,可从默认docs目录复制配置文件样例:

#  cp  /usr/share/doc/rabbitmq-server-3.7.10/rabbitmq.config.example   /etc/rabbitmq/rabbitmq.config

#   cat  /etc/rabbitmq/rabbitmq.config


配置文件特点:



在rabbitmq 3.7.0 之前,rabbitmq.conf 使用了erlang语法配置格式:

1. 配置文件的语法继承于erlang语言,有点类似json

2. 注释采用%%

3. 注意最后结尾一定要加上.,表示结束,否则启动会报错


在rabbitmq 3.7.0 之后,语法配置格式使用了sysctl 格式:

1. 单个信息都在一行里面

2. 配置信息以key value 的形式保存

3. # 开头表示注释


六、启用SSL安全通讯

Management Plugin

https://www.cnblogs.com/wyt007/p/9086250.html

https://www.rabbitmq.com/management.html#single-listener-https

https://github.com/Berico-Technologies/CMF-AMQP-Configuration




七、参考


rabbitmq的整体架构一览

https://blog.51cto.com/cuidehua/1769486


CentOS7 安装 RabbitMQ 3.7

https://blog.csdn.net/liang_henry/article/details/79584843


rabbitmq/erlang-rpm

https://github.com/rabbitmq/erlang-rpm


Downloading and Installing RabbitMQ

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

https://www.rabbitmq.com/install-rpm.html


Management Plugin

https://www.rabbitmq.com/management.html


Server Documentation

https://www.rabbitmq.com/admin-guide.html


rpm 安装RabbitMQ 3.7.7版本-User can only log in via localhost

https://blog.csdn.net/shenhonglei1234/article/details/82745601


rabbitMQ默认端口记录

https://blog.csdn.net/zhouxianling233/article/details/79623204


rabbitmqctl(8)

https://www.rabbitmq.com/rabbitmqctl.8.html


RabbitMQ手册之rabbitmqctl

https://www.jianshu.com/p/61a90fba1d2a


Networking and RabbitMQ

https://www.rabbitmq.com/networking.html


rabbitMQ基础篇

https://blog.csdn.net/ChengDianXiaoCai/article/details/72910333


rabbitMQ管理命令rabbitmqctl详解

https://www.ywnds.com/?p=4738


RabbitMQ :常用命令 与 图形管理 及 用户权限

https://www.jianshu.com/p/0964f6c46dc5


RabbitMQ on QingCloud AppCenter 用户手册

https://docs.qingcloud.com/product/big_data/rabbitmq/README.html#%E5%88%9B%E5%BB%BA-rabbitmq


rabbitmqadmin 命令行客户端工具

https://www.rabbitmq.com/management-cli.html


rabbitMQ配置文件

https://www.cnblogs.com/zhming26/p/6140307.html

https://www.rabbitmq.com/configure.html#configuration-file


rabbitmq-server/docs/rabbitmq.conf.example

https://github.com/rabbitmq/rabbitmq-server/blob/master/docs/rabbitmq.conf.example


rabbitmq之配置文件详解

https://www.cnblogs.com/cwp-bg/p/8397639.html


rabbitmq 生产环境配置

https://www.cnblogs.com/operationhome/p/10483840.html


RabbitMQ-官方指南-RabbitMQ配置

http://www.blogjava.net/qbna350816/archive/2016/08/02/431415.html


rabbitMQ消息队列: 启用SSL安全通讯

https://www.cnblogs.com/wyt007/p/9086250.html


CMF - AMQP - Configuration

https://github.com/Berico-Technologies/CMF-AMQP-Configuration


RabbitMQ技术入门与实战

https://blog.csdn.net/Super_RD/column/info/15500

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • Yum安装RabbitMQ3.6.11与Erlange20配置及优化 RabbitMQ简介 AMQP,即Advan...
    三杯水Plus阅读 4,547评论 0 7
  • 什么叫消息队列? 消息(Message)是指在应用间传送的数据。消息可以非常简单,比如只包含文本字符串,也可以更复...
    Agile_dev阅读 2,370评论 0 24
  • 应用场景 异步处理 场景说明:用户注册后,需要发注册邮件和注册短信,传统的做法有两种: 1.串行的方式 2.并行的...
    lijun_m阅读 1,815评论 0 3
  • http://liuxing.info/2017/06/30/Spring%20AMQP%E4%B8%AD%E6%...
    sherlock_6981阅读 15,892评论 2 11
  • 关于消息队列,从前年开始断断续续看了些资料,想写很久了,但一直没腾出空,近来分别碰到几个朋友聊这块的技术选型,是时...
    预流阅读 584,562评论 51 786