(1)RabbitMQ在Docker上安装
1.简介
在来学习RabbitMQ时候,我觉得很有必要先把它的环境先搭建起来,这样后面的示例才能进行。因为之前自己手动在Linux服务器上搭建过Elasticsearch,当时踩过太多坑了,浪费太多时间在这事情上,后面发现在Docker上安装部署方便快捷,不需要额外安装Erlang,所以写该篇文章先来介绍如何在Docker上部署RabbitMQ。
2. 安装Docker Engine-Community
使用Docker仓库进行安装,在新主机上首次安装Docker Engine-Community之前,需要设置Docker仓库。之后,您可以从仓库安装和更新Docker。
2.1设置仓库
安装所需的软件包。yum-utils提供了yum-config-manager,并且device mapper存储驱动程序需要device-mapper-persistent-data和lvm2。
sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
or
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
使用以下命令来设置稳定的仓库(一般不建议使用官方源地址,因为访问国外的站点比较慢,最好访问国内的源地址,例如阿里云):
$ sudo yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
or
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
2.2安装Docker Engine-Community
安装最新版本的Docker Engine-Community和containerd,或者转到下一步安装特定版本:
sudo yum install docker-ce docker-ce-cli containerd.io
2.3查看Docker版本
docker version
查看Docker版本时候,发觉Docker并没有启动,所以接下来要启动Docker。
2.4启动Docker
systemctl start docker
2.5通过运行hello-world映像来验证是否正确安装了Docker Engine-Community(当运行容器时,使用的镜像如果在本地中不存在,就会自动从docker镜像仓库中下载,默认是从Docker Hub公共镜像源下载)
docker run hello-world
2.6查看镜像
docker images
由此可见,docker下载安装成功!
3. Docker安装RabbitMQ
可以自行进入docker hub镜像仓库地址(https://hub.docker.com)查看rabbitmq类型的镜像。
3.1拉取rabbitmq镜像
docker pull rabbitmq
3.2查看镜像
拉取rabbitmq镜像成功!
3.3启动RabbitMQ Web界面
docker restart rabbitmq(REPOSITORY,容器名称)
docker restart 76615d52df27(CONTAINER ID,容器ID)
设置rabbitmq用户名和密码并启动主要有两种方式:
●默认guest 用户,密码guest:
docker run -d --hostname my-rabbit --name rabbit -p 15672:15672 -p 5672:5672 rabbitmq:management
●设置新用户名和密码:
docker run -d --hostname my-rabbit --name rabbitmq -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=qwer1234 -p 15672:15672 -p 5672:5672 rabbitmq:management
-d:后台运行容器。
--name:指定容器名。
-p:指定服务运行的端口(5672:应用访问端口;15672:控制台Web端口号)。
-v:映射目录或文件。
--hostname:主机名(RabbitMQ的一个重要注意事项是它根据所谓的“节点名称”存储数据,默认为主机名)。
-e:指定环境变量(RABBITMQ_DEFAULT_VHOST:默认虚拟机名;RABBITMQ_DEFAULT_USER:默认的用户名;RABBITMQ_DEFAULT_PASS:默认用户名的密码)。
●启动rabbitmq_management脚本命令如下:
docker exec -it rabbitmq rabbitmq-plugins enable rabbitmq_management
注意:rabbitmq为镜像名称。
3.4开启防火墙15672端口
firewall-cmd --zone=public --add-port=15672/tcp --permanent
firewall-cmd --reload
--查看是否开通访问权限
firewall-cmd --permanent --zone=public --query-port=15672/tcp
注:如果是阿里云等服务器,则需要配置RabbitMQ安全组策略
登录阿里云->安全组规则->访问规则->入方向->手动添加如下策略:
3.5查看正在运行容器
docker ps -a
3.6 rabbitmqctl用户命令使用
当你使用rabbitmqctl用户命令时有如下提示:
rabbitmqctl: command not found
则是因为rabbitmqctl没有进行软连接,需要进入到rabbitmqctl的sbin目录下执行rabbitmqctl命令才有用。假设我要修改admin用户密码,需要找到rabbitmqctl的sbin目录并切换才能执行命令,如果不清楚目录在哪里,可以通过find命令查找:
find / -name "rabbitmqctl*"
3.6.1用户相关命令
●查看用户列表
rabbitmqctl list_users
●增加用户
rabbitmqctl add_user username 'password'
●设置角色
rabbitmqctl set_user_tags username administrator
●修改用户密码
rabbitmqctl change_password username 'newpasswd'
●删除用户
rabbitmqctl delete_user username
●用户赋权(使用户user1具有vhost1这个virtual host中所有资源的配置、写、读权限以便管理其中的资源)
rabbitmqctl set_permissions -p vhost1 username '.*' '.*' '.*'
●查看权限
rabbitmqctl list_user_permissions username
●查看vhost1中权限
rabbitmqctl list_permissions -p vhost1
●清除权限
rabbitmqctl clear_permissions [-p VHostPath] username
3.6 Docker重启RabbitMQ
●查看正在运行容器:
docker ps -a
●停止运行rabbitmq容器:
docker stop 9f1fb347efc2 (CONTAINER ID)
●删除rabbitmq容器:
docker rm 9f1fb347efc2(CONTAINER ID)
●再执行3.3小节rabbitmq启动命令
3.7安装成功
参考文献:
CentOS Docker安装
Docker镜像使用
Docker容器使用
Docker容器连接
(1)RabbitMQ在Docker上安装的更多相关文章
- CI与CD之Docker上安装Jenkins
一.CI,CD,Jenkins的介绍 CI:持续集成(Continuous integration,简称 CI),在传统的软件开发环境中,有集成,但是没有持续集成这种说法,长时间的分支与主干脱离,导致 ...
- Docker上安装Redis
Docker可以很方便的进行服务部署和管理,下面我们通过docker来搭建Redis的单机模式.Redis主从复制.Redis哨兵模式.Redis-Cluster模式 一.在Docker上安装单机版R ...
- docker上安装elasticsearch和ik分词器插件和header,实现分词功能
docker run -di --name=tensquare_es -p 9200: -p 9300:9300 elasticsearch:5.6.8 创建elasticsearch容器(如果版本不 ...
- docker上安装nginx服务
环境 1.开启一个容器,安装nginx,略过 2.假如第一步新启动没映射端口的话,重新把容器保存为镜像然后再重新运行一个新容器,不建议在一个正在运行的容器上做端口映射 docker run ...
- 在Docker上安装配置Oracle教程
地址:https://github.com/wnameless/docker-oracle-xe-11g Docker shell 下: docker pull wnameless/oracle-xe ...
- docker上安装eslaticsearch
一 elasticsearch安装 1 查找镜像: docker search elasticsearch 可以看到如下截图; 2 拉取镜像 docker pull elasticsearch 我并没 ...
- 在腾讯CentOS7.4云服务器上安装Docker,在Docker上安装配置MySQL、Tomcat和Nginx
提示:以下是在腾讯CentOS7.4云服务器上操作. Docker的基本操作:https://www.cnblogs.com/opsprobe/p/10963098.html 一.安装Docker # ...
- rabbitmq在mac上安装
1.安装brew 打开http://bash.sh 执行 ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/ ...
- 在单机Docker上安装 Traefik 反向代理-负载均衡器
一.创建Traefik和容器应用的连接网络 sudo docker network create traefik-net 二.下载Traefik样本配置文件wget https://raw.githu ...
随机推荐
- 几百行代码写个Mybatis,原理搞的透透的!
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 Mybatis 最核心的原理也是它最便于使用的体现,为什么这说? 因为我们在使用 M ...
- SQL 查询总是先执行SELECT语句吗?你们都错了!
SELECT语句中子句的顺序.SELECT语句中使用时必须遵循的次序. 经过一段时间的学习,我们知道了SELECT语句超简版的语法如下: SELECT 字段名 FROM 表名 后来,我们又陆续学习了W ...
- SQL Server存储过程执行一个带返回值(output)的存储过程
语法如下: --存储过程一CREATE PROCEDURE testProc @out VARCHAR(500) OUTPUT AS BEGIN SET @out='操作成功' RETURNEND - ...
- shell中cmd1 && cmd2 || cmd3的含义
在某些情况下,很多指令我想要一次输入去执行,而不想要分次去执行时,就要用到 && || 了.cmd 1 && cmd21,若cmd1执行完毕之后且正确执行($?=0), ...
- docker报错Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
docker报错Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon run ...
- PWN——uaf漏洞学习
PWN--uaf漏洞 1.uaf漏洞原理 在C语言中,我们通过malloc族函数进行堆块的分配,用free()函数进行堆块的释放.在释放堆块的过程中,如果没有将释放的堆块置空,这时候,就有可能出现us ...
- Burp - Turbo Intruder
Turbo Intruder 基础使用总结,把Python代码都记录下,要是有啥骚姿势,求各位师傅交流. 个人感觉超强的一款Burp插件,反正超快 Link: https://github.com/P ...
- java环境的配置——实现win10下双击直接运行jar文件
java环境的配置--实现win10下双击直接运行jar文件 在渗透测试的过程中很多工具的安装和使用需要java环境,下面我来介绍一下java环境配置的超详细步骤(包含怎样实现win10下双击直接运行 ...
- Hello World!!
已经工作了一年多,现在才开始写博客.话说,种一棵树最好的时机是十年前,其次是现在,我觉得不迟.俗话说滴水穿石,我想把一些东西,都慢慢积累起来,看见自己的成长.既方便查看,更不容易忘记.可能在网上已经有 ...
- Elasticsearch IK分词器
Elasticsearch-IK分词器 一.简介 因为Elasticsearch中默认的标准分词器(analyze)对中文分词不是很友好,会将中文词语拆分成一个一个中文的汉字,所以引入中文分词器-IK ...