关于mongodb:备份-docker-容器内的-mongo数据库

3次阅读

共计 1083 个字符,预计需要花费 3 分钟才能阅读完成。

前言

之前本人写了一个集体博客,整体技术栈为:Vue + node + mongo,之前就是一个小白,啥也不懂没有设置权限,也没有批改端口,也没有限度近程登录 host……

忽然有一天,发现数据全副没有了(被黑)

前面小白一直成长,摸索出了 jenkins + docker 实现了主动构建和部署,其中 mongo 被我部署进了 docker 容器

当初有个问题,我想定期的去备份数据,以备不时之需

人力备份

什么叫人力备份,就是手工的把 mongo 容器内的数据备份,流程:

  • 进入 mongo 容器,备份数据
  • 拷贝 mongo 容器的数据到宿主机机器

1. mongo 容器内备份数据

找到正在运行中的 mongo 容器,这里是 3dcf2168ed94

docker images

进入 mongo 容器

docker exec -it 3dcf2168ed94 sh

咱们新建一个备份目录,假如是 /root/blog

执行 mongodump 命令,导出 blog 整个数据库到当前目录

# 导出 blog 数据库 到当前目录
mongodump -h localhost:27017 -d blog -o ./

能够看到,曾经胜利备份了容器的数据,咱们退出,回到宿主机器

exit

2. 拷贝容器数据到宿主机

执行命令:

# 拷贝 3dcf2168ed94 容器内的 /root/blog  => 当前目录(宿主机器)docker cp 3dcf2168ed94:/root/blog ./

完满,数据胜利备份进去了

主动备份

每次都手工太吃力了,于是偷懒的我想了个法子

1. 主动挂载

docker 容器内的目录其实是能够主动挂载到宿主机的

# docker-compose.yml
# 宿主机的 /root/blog-backend/data 映射到 容器内的 /data/db
/root/blog-backend/data:/data/db

2. 定时工作备份数据

我这里做的是定时工作每天都会去执行一个函数,这个函数的性能就是备份数据到某个目录,而后该目录会主动映射到宿主机器,造成一个闭环

我这里用的是 eggjg,每天备份一次

# /app/schedule/backup.ts
export default class BackUp extends Subscription {static get schedule() {
    return {
      interval: '1d', # 每天备份一次
      type: 'all',
    };
  }
  async subscribe() {
    try {// 备份数据} catch (e) {console.log(e);
      this.ctx.logger.error(`${new Date()}:备份数据失败 `);
    }
  }
}

完满,终于能够欢快地摸鱼了~.~

我的博客


END

正文完
 0