使用 docker 一键部署 MongoDB

目录

[1. 前期准备](#1. 前期准备)

[2. 导入镜像](#2. 导入镜像)

[3. 部署MongoDB脚本](#3. 部署MongoDB脚本)

[4. 配置模板文件](#4. 配置模板文件)

[5. 部署MongoDB](#5. 部署MongoDB)

[6. 部署后配置](#6. 部署后配置)

[7. 基本维护](#7. 基本维护)


1. 前期准备

新部署前可以从仓库(repository)下载 MongoDB 镜像,或者从已有部署中的镜像生成文件:

复制代码
# 查看当前本地镜像
docker images
# 生成本地镜像文件
docker save <IMAGE ID> -o mongodb_3015.tar

生成 MongoDB 副本集所需的 autokey 文件:

复制代码
# 建立autokey文件
openssl rand -base64 756 > autokey
# 修改读写模式
chmod 400 autokey

2. 导入镜像

复制代码
# 在新部署的机器上导入镜像
docker load -i mongodb_3015.tar
docker images

3. 部署MongoDB脚本

mongodb-deploy.sh 文件内容如下:

复制代码
#!/bin/bash

mkdir -p /usr/local/docker/mongodb/conf
mkdir -p /usr/local/docker/mongodb/data
cp /root/autokey /usr/local/docker/mongodb/data/
cp /root/mongodb.conf.template /usr/local/docker/mongodb/conf/mongodb.conf
chown -R polkitd:root /usr/local/docker/mongodb/

docker run --name mongo \
-v /usr/local/docker/mongodb/data:/data/db \
-v /usr/local/docker/mongodb/conf:/data/conf \
-p 27017:27017 \
-e TZ=Asia/Shanghai \
-itd a.com:8443/dockerhub/mongo:3.0.15 \
--replSet mvbox_new

4. 配置模板文件

mongodb.conf.template 文件内容如下:

复制代码
port            = 27017
logpath         = /data/db/mongodb.log
pidfilepath     = /data/db/mongodb.pid
dbpath          = /data/db/
logappend       = true
fork            = true
journal         = true
directoryperdb  = true
auth            = true
maxConns        = 1000
profile         = 1
replSet         = mvbox_new
keyFile         = /data/db/autokey

5. 部署MongoDB

复制代码
# 在所有 MongoDB 副本集机器执行
./mongodb-deploy.sh

6. 部署后配置

在 primary 机器上执行下面的操作。

复制代码
# 配置副本集
cp /root/rs_initiate.js /usr/local/docker/mongodb/data/
docker exec -it mongo mongo --port 27017 /data/db/rs_initiate.js

rs_initiate.js 文件内容如下:

复制代码
rs.initiate(
   {
      _id: "mvbox_new",
      version: 1,
      members: [
         { _id: 0, host : "172.18.29.56:27017", priority:2 },
         { _id: 1, host : "172.18.29.57:27017", priority:1 },
         { _id: 2, host : "172.18.29.58:27017", priority:1 }
      ]
   }
)

# 创建 admin 用户
docker exec -it mongo mongo --port 27017

use admin;
db.createUser({user : "admin", pwd : "123456", roles: [ { role : "root", db : "admin" } ] });
exit;

# 重新登录,创建更多用户
docker exec -it mongo mongo --port 27017 -u admin -p 123456 admin

use admin
db.createUser({user : "vvmusic_msg", pwd : "123456", roles: [ { role : "dbOwner", db : "vvmusic_msg" } ] });
db.createUser({user : "vvlive", pwd : "123456", roles: [ { role : "dbOwner", db : "vvlive" } ] });
use vvmusic_msg
db.createUser({user : "vvmusic_msg", pwd : "123456", roles: [ { role : "dbOwner", db : "vvmusic_msg" } ] });
use vvlive
db.createUser({user : "vvlive", pwd : "3123456", roles: [ { role : "dbOwner", db : "vvlive" } ] });
exit;

# 验证用户登录
docker exec -it mongo mongo --port 27017 -u admin -p 123456 admin
docker exec -it mongo mongo --port 27017 -u vvlive -p 123456 admin
docker exec -it mongo mongo --port 27017 -u vvlive -p 123456 vvlive
docker exec -it mongo mongo --port 27017 -u vvmusic_msg -p 123456 admin
docker exec -it mongo mongo --port 27017 -u vvmusic_msg -p 123456 vvmusic_msg

7. 基本维护

复制代码
# 查看镜像
docker images
# 查看容器
docker ps
# 查看容器详细信息
docker inspect <CONTAINER ID>
# 重启容器
docker restart mongo
# 停止容器
docker stop mongo
# 删除容器
docker rm mongo
相关推荐
Sirius Wu2 小时前
Docker 镜像的构建、打包、变更、再次打包全流程
运维·docker·容器
Zhu7583 小时前
【软件部署】docker环境部署domino
运维·docker·容器
.柒宇.6 小时前
信创实战:银河麒麟 V10 服务器安装、网络配置与 Docker 环境搭建
linux·运维·docker·国产信创·麒麟操作系统
IT从业者张某某6 小时前
基于Docker的hadoop容器安装hive并测试
hive·hadoop·docker
杨浦老苏6 小时前
Docker容器管理面板Dockhand
运维·docker·群晖
努力的搬砖人.6 小时前
配置 Docker 镜像加速器
运维·docker·容器
江湖有缘6 小时前
实时监控所有端口,Docker 部署 WatchYourPorts 保姆级教程
运维·docker·容器
IT从业者张某某7 小时前
基于Docker的hadoop容器安装zookeeper
hadoop·docker·zookeeper
guojb8247 小时前
告别部署踩坑:用 Docker Compose 优雅搞定多前端站点、HTTPS 与 SSE 推送
nginx·docker·https
pupudawang7 小时前
docker desktop安装redis
redis·docker·容器