docker常用容器部署,附加指定挂载目录等命令

部署mysql

以5.7为例

  1. Dokcer pull mysql:5.7
  2. 创建目录,用于挂载容器内数据文件: xxx/docker/mysql/data、 xxx/docker/mysql/logs、 xxx/docker/mysql/conf
  3. 执行命令
docker run -d -p 3306:3306 --name mysql \
-e MYSQL_ROOT_PASSWORD=root \
-v  xxx/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf \
-v xxx/docker/mysql/data:/var/lib/mysql \
mysql:5.7

8.0版本需要多一个挂载目录,否则会报错: Error on realpath() on ‘/var/lib/mysql-files’ (Error 2 - No such file or directory

-v xxx/docker/mysql/mysql-files:/var/lib/mysql-files

其次,8.0需要开启远程连接,否则127.0.0.1:3306 无法连接

//1.登录mysql
mysql -uroot -p
//2.对root用户进行授权
GRANT ALL ON *.* TO 'root'@'%';
//3.刷新权限
flush privileges;

注意: -v 为指定挂载目录 冒号前面是指定目录,冒号后面是容器内部目录

部署redis

以6.2为例

  1. Dokcer pull redis:6.2
  2. 创建目录,用于挂载容器内数据文件: xxx/docker/redis/data、 xxx/docker/redis/conf
  3. 创建redis.conf文件 可在官网下载,类似于nginx把配置文件放到宿主机上,方便进行修改
    官网下载conf文件地址:https://redis.io/docs/manual/config/ (也可先运行一个redis容器,然后拷贝到宿主机使用,再次创建容器即可)
  4. 执行命令
docker run -it -d -p 6379:6379 --name redis \
-v xxx/docker/redis/conf/redis.conf:/etc/redis/redis.conf \
-v xxx/docker/redis/data:/data \
redis:6.2 \
redis-server /etc/redis/redis.conf \
--appendonly yes

关于本地链接redis失败问题:

有一个前提:在docker部署redis时指定了挂载目录(不指定挂载目录是可以直接通过127.0.0.1:6379连接的),和两个因素:

  • 配置文件中的bind命令 bind 127.0.0.1
  • 配置文件中的命令 protected-mode yes

目前我所知道的解决方法针对于某些版本:

  1. 针对6.2版本,两个方式 ①是把bind 127.0.0.1改为bind 0.0.0.0,②是把protected-mode yes改为protected-mode no,这两个任意一项都可以使127.0.0.1连接成功
  2. 针对7.0版本,需要把bind 127.0.0.1注释掉,并且把protected-mode yes改为protected-mode no才可以使127.0.0.1连接成功

具体的原理原因,可以自行查阅redis配置的绑定IP地址,和关闭保护模式。

注意: -v 为指定挂载目录 冒号前面是指定目录,冒号后面是容器内部目录

部署MongoDB

以5.0为例

  1. Dokcer pull mongo::5.0
  2. 创建目录,用于挂载容器内数据文件: xxx/docker/mongo/data
  3. 执行命令
docker run -d --name mongodb \
-v xxx/docker/mongo/data:/data \
-p 27017:27017 \
-e MONGO_INITDB_ROOT_USERNAME=admin \
-e MONGO_INITDB_ROOT_PASSWORD=admin \
--privileged=true \
mongo:5.0

部署Rocketmq

部署namesrv

  1. 拉取镜像:
docker pull rocketmqinc/rocketmq
  1. 创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/namesrv/logs、xxx/docker/rocketmq/data/namesrv/store

  2. 执行命令

docker run -d \
--restart=always \
--name rmqnamesrv \
-p 9876:9876 \
-v ~/docker/rocketmq/data/namesrv/logs:/root/logs \
-v ~/docker/rocketmq/data/namesrv/store:/root/store \
-e "MAX_POSSIBLE_HEAP=100000000" \
foxiswho/rocketmq \
sh mqnamesrv

部署broker

  1. 镜像与namesrv使用的是相同,不需要拉取

  2. 创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/broker/logs、xxx/docker/rocketmq/data/broker/store、 xxx/docker/rocketmq/conf

  3. 创建配置文件:broker.conf

# 所属集群名称,如果节点较多可以配置多个
brokerClusterName = DefaultCluster
#broker名称,master和slave使用相同的名称,表明他们的主从关系
brokerName = broker-a
#0表示Master,大于0表示不同的slave
brokerId = 0
#表示几点做消息删除动作,默认是凌晨4点
deleteWhen = 04
#在磁盘上保留消息的时长,单位是小时
fileReservedTime = 48
#有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机制;
brokerRole = ASYNC_MASTER
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH
# broker节点所在服务器的ip地址
brokerIP1 = 192.168.100.9
# docker内部容器namesrvAddr地址
namesrvAddr= 172.17.0.6:9876
  1. 执行命令
docker run -d  \
--restart=always \
--name rmqbroker \
--link rmqnamesrv:namesrv \
-p 10911:10911 \
-p 10909:10909 \
-v  ~/docker/rocketmq/data/broker/logs:/root/logs \
-v  ~/docker/rocketmq/data/broker/store:/root/store \
-v ~/docker/rocketmq/conf/broker.conf:/docker/rocketmq/conf/broker.conf \
-e "NAMESRV_ADDR=namesrv:9876" \
-e "MAX_POSSIBLE_HEAP=200000000" \
rocketmqinc/rocketmq \
sh mqbroker -c /docker/rocketmq/conf/broker.conf

创建rockermq-console

  1. 拉取镜像:
docker pull styletang/rocketmq-console-ng
  1. 创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/namesrv/logs、xxx/docker/rocketmq/data/namesrv/store

  2. 执行命令,这里的地址是docker内部容器namesrvAddr地址与配置文件保持一直

docker run \
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.17.0.6:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \
-p 8080:8080 \
-t styletang/rocketmq-console-ng \
--restart=always \
--name rmqadmin

访问localhost:8090/ ,即可查看部署好的mq信息

追加自动重启命令

docker update --restart=always 容器名, 最多重启三次策略: --restart=on-failure:3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值