Linux下RabbitMQ安装、运行与管理

安装erlang

安装参考官网

RabbitMQ的安装需要Erlang的基础环境,必须按照RabbitMQ Erlang版本要求进行安装。

关于Erlang官方的安装方式有三种:

官方制作的依赖软件包
Erlang Solutions的软件包(这个可以自定义yum库安装,本人自己下载安装)
EPEL(“Enterprise Linux的额外软件包”)

  

1.依赖环境安装

yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel unixODBC unixODBC-devel httpd python-simplejson

2.获取安装文件

wget http://erlang.org/download/otp_src_19.2.tar.gz

3.解压erlang安装包 

tar -xzvf otp_src_19.2.tar.gz

4. cd erlang目录 

cd otp_src_19.2

5.编译安装erlang语言环境--prefix=/usr/local/erlang为安装目录

./configure  --prefix=/usr/local/erlang

6.编译安装

make && make install

7.配置环境变量

vi /etc/profile

export PATH=$PATH:/usr/local/erlang/bin

source /etc/profile

8.验证是否安装成功 

erl

  

安装RabbitMQ

安装指南  安装版本选择

1.cd到指定目录

cd /usr/local  //切换到计划安装RabbitMQ的目录,我这里放在/usr/local

2.下载

wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.1/rabbitmq-server-generic-unix-3.6.1.tar.xz  //下载RabbitMQ安装包

3.解压

xz -d rabbitmq-server-generic-unix-3.6.1.tar.xz

 

tar -xvf rabbitmq-server-generic-unix-3.6.1.tar

4.改名

mv rabbitmq_server-3.6.1/ rabbitmq

5.配置rabbitmq环境变量

vi /etc/profile
#set rabbitmq environment
export PATH=$PATH:/usr/local/rabbitmq/sbin
source /etc/profile

  

RabbitMQ 运行和管理

 运行常用命令

//常用的rabbitmq的命令
service rabbitmq-server start
service rabbitmq-server stop
service rabbitmq-server status
service rabbitmq-server rotate-logs|
service rabbitmq-server restart
service rabbitmq-server condrestart
service rabbitmq-server try-restart
service rabbitmq-server reload
service rabbitmq-server force-reload
service rabbitmq-server -detached //后台启动
ps -ef | grep rabbitmq 查看rabbitMq进程 netstat -anplt | grep LISTEN rabbitmq默认监听端口15672/5672

web管理

 15672 网页管理,  5672 AMQP端口
rabbitmq默认创建的用户guest,密码也是guest,这个用户默认只能是本机访问,localhost或者127.0.0.1,从外部访问需要添加上面的配置。
//先创建目录,以免报错
mkdir /etc/rabbitmq //开启管理页面插件
rabbitmq-plugins enable rabbitmq_management
管理插件安装完成后,出现如下提示,表示安装成。
The following plugins have been enabled:
mochiweb
webmachine
rabbitmq_web_dispatch
amqp_client
rabbitmq_management_agent
rabbitmq_management
Plugin configuration has changed. Restart RabbitMQ for changes to take effect.

重启rabbitmq服务

service rabbitmq-server restart
可以用浏览器输入localhost:15672,账号密码全输入guest即可登录

配置防火墙

配置linux 端口 15672 网页管理 5672 AMQP端口:

firewall-cmd --permanent --add-port=15672/tcp
firewall-cmd --permanent --add-port=5672/tcp
systemctl restart firewalld.service

  

管理常用命令

查看mq用户:rabbitmqctl list_users  

查看用户权限:rabbitmqctl list_user_permissions guest

新增用户: rabbitmqctl add_user admin 123456

赋予管理员权限:

rabbitmqctl set_user_tags admin administrator 

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

  

可以创建管理员用户,负责整个MQ的运维,例如:
rabbitmqctl add_user user_admin passwd_admin 赋予其administrator角色:
rabbitmqctl set_user_tags user_admin administrator 可以创建RabbitMQ监控用户,负责整个MQ的监控,例如:
rabbitmqctl add_user user_monitoring passwd_monitor 赋予其monitoring角色:
rabbitmqctl set_user_tags user_monitoring monitoring 可以创建某个项目的专用用户,只能访问项目自己的virtual hosts
sudo rabbitmqctl add_user user_proj passwd_proj 赋予其monitoring角色:
rabbitmqctl set_user_tags user_proj management 创建和赋角色完成后查看并确认:
rabbitmqctl list_users

  

RabbitMQ用户角色及权限控制

1.RabbitMQ的用户角色分类:

none、management、policymaker、monitoring、administrator

2.RabbitMQ各类角色描述:

none

不能访问 management plugin

management

用户可以通过AMQP做的任何事外加:

列出自己可以通过AMQP登入的virtual hosts 

查看自己的virtual hosts中的queues, exchanges 和 bindings

查看和关闭自己的channels 和 connections

查看有关自己的virtual hosts的“全局”的统计信息,包含其他用户在这些virtual hosts中的活动。

policymaker

management可以做的任何事外加:

查看、创建和删除自己的virtual hosts所属的policies和parameters

monitoring 

management可以做的任何事外加:

列出所有virtual hosts,包括他们不能登录的virtual hosts

查看其他用户的connections和channels

查看节点级别的数据如clustering和memory使用情况

查看真正的关于所有virtual hosts的全局的统计信息

administrator  

policymaker和monitoring可以做的任何事外加:

创建和删除virtual hosts

查看、创建和删除users

查看创建和删除permissions

关闭其他用户的connections

  

最新文章

  1. Delphi编程时候诡异地出现ORA-00937错误,记录解决它的思路和方法
  2. 转载:《TypeScript 中文入门教程》 6、命名空间
  3. grep使用多个查询条件--或
  4. ClojureScript魔法堂:搭建开发环境
  5. PHP条件语句语法与示例
  6. 2016暑假多校联合---Windows 10
  7. 关于ASP.NET或VS2005 搭建三层架构的理解
  8. [BTS] Exception occurred when persisting state to the database
  9. GL_GL系列 - 预算管理分析(案例)
  10. 可视化数据包分析工具-CapAnalysis
  11. HW4.2
  12. Unix时间戳 和 NSDate 的转换
  13. Buy the Ticket HDU 1133 递推+大数
  14. JavaEE开发之Spring中的条件注解组合注解与元注解
  15. DbContext 中的 Explicit interface implementation
  16. springMVC源码分析--AbstractHandlerMethodMapping获取url和HandlerMethod对应关系(十)
  17. redux-thunk 源码学习记录
  18. Scikit-learn 安装
  19. SQL Server Profiler的简单使用
  20. sas和ssd盘写入数据效率对比

热门文章

  1. Spring Cloud架构教程 (三)服务网关(基础)
  2. 2018-2019-2 20165235《网络对抗技术》Exp7 网络欺诈防范
  3. C#调用windows API实现 smallpdf客户端程序进行批量压缩
  4. Python 使用PyQt5进行开发(一)
  5. Python深度学习读书笔记-1.什么是深度学习
  6. java kryo序列化与反序列化
  7. 如何比较两个txt文件内容的细微差别
  8. pycharm基础使用方法
  9. 判断Ctrl Shift Alt 键当前是否被按下
  10. 【不错】MySQL 事务隔离级别