MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。

Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

1、阿里云MongoDB还原备份到自建MongoDB步骤

1.1、下载阿里云MongoDB备份文件

使用wget命令下载阿里云数据库备份

阿里云文档说明:https://help.aliyun.com/document_detail/58329.html?spm=a2c6r.11610030.0.0.3aea42313v84vh

wget -c -O /tmp/hins7699283_data_20190603235309_qp.xb '阿里云备份URL地址'

1.2、安装阿里云备份文件解压工具(以单节点模式恢复MongoDB物理备份的数据)

1.安装epel包

yum install -y epel-release 

2.通过以root用户或sudo运行以下命令来安装Percona yum存储库 

yum install -y https://repo.percona.com/yum/percona-release-latest.noarch.rpm

3.启用存储库

percona-release enable-only tools release

4.运行以下命令安装Percona XtraBackup工具

Percona XtraBackup是一个基于MySQL的服务器的开源热备份实用程序 ,它不会在备份期间锁定您的数据库。
无论是24x7高负载服务器还是低事务量环境,Percona XtraBackup都旨在使备份成为一个无缝过程,而不会破坏生产环境中服务器的性能。

yum install -y percona-xtrabackup-

5.安装qpress才能使用innobackupex命令

qpress是使用QuickLZ的便携式文件存档器,旨在最大程度地利用快速存储系统。它通常比文件复制要快,因为目标小于源。

wget -c https://files.cnblogs.com/files/Sungeek/qpress-11-linux-x64.tar
tar xvf qpress--linux-x64.tar
chmod qpress
cp qpress /usr/bin

6.解压物理备份文件,例如数据库备份文件名为hins20191107_qp.xb

[root@localhost ~]#  cd  /data/mongodb/mongodb3717/data/
[root@localhost ~]# mv /tmp/hins20191107_qp.xb /data/mongodb/mongodb3717/data/
[root@localhost ~]# cat hins20191107_qp.xb | xbstream -x -v
[root@localhost ~]# innobackupex --decompress --remove-original ./
[root@localhost ~]# chown -R mongodb.mongodb /data/mongodb/mongodb3717/

注意:如果原来数据库有数据可以先删除,停mongo服务,删除所有数据库文件

[root@localhost ~]# /usr/local/mongodb/bin/mongo --host 127.0.0.1 --port  admin -uroot -p123456 --authenticationDatabase admin --eval 'db.shutdownServer({force:true})'

[root@localhost ~]#  cd  /data/mongodb/mongodb3717/data/

[root@localhost ~]#  rm -rf ./*

7.修改配置文件,把wiredTigerDirectoryForIndexes参数、replSet参数、oplogSize参数、keyFile参数注释掉

vi /etc/mongod.conf
#wiredTigerDirectoryForIndexes=true #为索引文件指定独立目录
#replSet=rpl
#oplogSize= #oplog大小
#keyFile=/data/mongodb/mongodb3717/data/mongodb-keyfile
#auth = true #

8.启动mongo服务

/etc/init.d/mongod start

1.3、副本集模式启动MongoDB数据库

云数据库MongoDB的物理备份默认带有原实例的副本集配置。启动时需以单节点模式启动,否则可能无法访问。

如需以副本集模式启动,需要先以单节点模式恢复MongoDB数据,再按照以下步骤执行:

1.先通过服务器的mongo shell登录MongoDB数据库。

mongo --host 127.0.0.1 -u <username> -p <password> --authenticationDatabase admin

2.移除原有副本集配置。

#主库执行
use local
db.system.replset.remove({})

3.关闭mongodb进程服务。

use admin
db.shutdownServer()

4.修改/etc/目录下的配置文件mongod.conf,添加replication相关配置。详细命令用法请参见MongoDB官方文档部署副本集

5.指定新建的配置文件 mongod.conf 来启动 MongoDB。

/etc/init.d/mongod -f /etc/mongod.conf

6.将成员加入副本集并初始化副本集。

说明:此步骤使用rs.initiate()命令进行操作,详细命令用法请参见MongoDB官方文档rs.initiate()命令介绍

rs.initiate(
{
_id: "myReplSet",
version: 1,
members: [
{ _id: 0, host : "mongodb0.example.net:3717" },
{ _id: 1, host : "mongodb1.example.net:3717" },
{ _id: 2, host : "mongodb2.example.net:3717" }
]
}
)

2、自建MongoDB还原到阿里云MongoDB

1.先登录自建的MongoDB备份

--备份所有库

/usr/local/mongodb/bin/mongodump --host 127.0.0.1 --port 3717 --authenticationDatabase admin --username root --password 密码  --out=/tmp/tse-MongoDB-20191107

--备份单个库(加--db参数)

/usr/local/mongodb/bin/mongodump --host 127.0.0.1 --port 3717 --authenticationDatabase admin --username root --password 密码 --db local --out=/tmp/tse-local-20191107

2.自建MongoDB服务器连接登录阿里云MongoDB

--测试登录成功以后开始还原刚刚的备份

/usr/local/mongodb/bin/mongo --host 填写阿里云公网URL --port 3717 admin -uroot -p阿里云MongoDB密码 --authenticationDatabase admin

--还原所有库到阿里云MongoDB

/usr/local/mongodb/bin/mongorestore  --host 阿里云公网URL --port 3717 --authenticationDatabase admin --username root --password 阿里云mongo密码  --drop  --stopOnError    /tmp/tse-MongoDB-20191107

--还原单个库到阿里云MongoDB

/usr/local/mongodb/bin/mongorestore  --host 阿里云公网URL --port 3717 --authenticationDatabase admin --username root --password 阿里云mongo密码  --drop  --stopOnError  --db local  /tmp/tse-local-20191107

提示:阿里云MongoDB需要开启自建服务器白名单才可以登录连接。

MongoDB自建和阿里云RDS备份还原的更多相关文章

  1. 阿里云rds 备份和还原

    阿里云rds 备份和还原 转发:https://www.cnblogs.com/lin1/p/8617764.html 转发:https://help.aliyun.com/knowledge_det ...

  2. 阿里云RDS备份 恢复到本地

    目录 一.恢复准备 二.具体操作 一.恢复准备 阿里云RDS默认配置了全备份+binlog,可以精准恢复到某个时间点上. 可以下载备份的包到本地,进行本地恢复,要预留好本地的数据库容量和cpu等规格, ...

  3. 阿里云RDS备份的tar格式包恢复到本地自建数据库

    说明 阿里云RDS-mysql数据库是通过percona-Xtrabackup进行备份的,所以恢复时也需要安装该软件. 另外注意的是:你自己下载的MySQL版本要和阿里云上的MySQL版本一致,不然会 ...

  4. 阿里云RDS备份在本地mysql快速还原

    本地准备: ##安装和RDS相同的mysql版本,拿mysql5.6为例 http://www.cnblogs.com/37yan/p/7513605.html ##安装Xtrabackup 包 cd ...

  5. wget下载阿里云RDS备份集

    [root@localhost tmp]# more wget.sh #!/bin/bash download_url=`python /tmp/geturl.py` echo $download_u ...

  6. 阿里云RDS数据库备份同步到自建库方法(SHELL脚本)

    一.背景: 由于阿里云RDS生产库每天都需要备份且拷贝到自建读库,而如果使用阿里云的自动拷贝到只读实例, 费用太高, 故采用自编写同步脚本方法实现. 二.前提: 1). 已开通阿里云RDS, 且开启定 ...

  7. 阿里云RDS for SQL Server使用的一些最佳实践

    了解RDS的概念 这也是第一条,也是最重要的一条,在使用某项产品和服务之前,首先要了解该产品或服务的功能与限制,就像你买一个冰箱或洗衣机,通常也只有在阅读完说明书之后才能利用起来它们的所以功能,以及使 ...

  8. 阿里云RDS数据库改造迁移方案

    1. 改造原因 (1) 由于历史原因, 本应该是同一个库的表分布在两个数据库中,需要对这两个库进行合并. (2) 已有的数据库性能无法满足业务的增长需要, 查询卡,慢问题突出. (3) 当前自建Mys ...

  9. 阿里云RDS与ECS服务器数据库做主从

    阿里云RDS与ECS服务器数据库做主从 [精] 里云RDS(数据库)基于飞天大规模分布式计算和存储能力,提供超高性价比的单机版实例,同时利用读写分离横向扩展读能力,满足网站类的业务需求.提供稳定.高性 ...

随机推荐

  1. Java 多线程练习

    题目:某公司组织年会,会议入场时有两个入口,在入场时每位员工都能获取一张双色球彩票,假设公司有100个员工,利用多线程模拟年会入场过程, 并分别统计每个入口入场的人数,以及每个员工拿到的彩票的号码.线 ...

  2. [Abp vNext 源码分析] - 9. 接口参数的验证

    一.简要说明 ABP vNext 当中的审计模块早在 依赖注入与拦截器一文中有所提及,但没有详细的对其进行分析. 审计模块是 ABP vNext 框架的一个基本组件,它能够提供一些实用日志记录.不过这 ...

  3. vue-cli 脚手架安装

    1.安装node;选择适合自己系统的文件,下载一路next , a安装成功后,打开运行输入cmd 进入命令行: 在命令行工具中输入 npm -v  检查版本号 如果出现 则安装成功:(npm为node ...

  4. 快学Scala 第七课 (类构造函数)

    类 主构造器: class Person (var name: String){ } 主构造参数可以不带val或者var,如果没有被其他方法使用,则不保存为字段. 如果被其他方法使用,则被升格为字段, ...

  5. 定期从Docker上部署的MySQL备份数据

    前段时间公司停电,正巧赶上周一领导要开会要过一遍项目,然而项目所依赖的MySQL数据库是直接部署在宿主机,且因为各人部署方式不同的原因,花了很久才在开会前启动起来.于是开完会后,我第一件事就是把原先依 ...

  6. 利用JVM在线调试工具排查线上问题

    在生产上我们经常会碰到一些不好排查的问题,例如线程安全问题,用最简单的threaddump或者heapdump不好查到问题原因.为了排查这些问题,有时我们会临时加一些日志,比如在一些关键的函数里打印出 ...

  7. inkscape 无法打开文档属性

    从文件->文档属性 点击了无反应 参考https://bugs.launchpad.net/inkscape/+bug/1664031 其实不是无反应,只是因为我们自己的某些操作,让文档属性这个 ...

  8. 从0开始学FreeRTOS-(消息队列)-5

    ## 问题解答 曾经有人问我,FreeRTOS那么多API,到底怎么记住呢? 我想说,其实API不难记,就是有点难找,因为FreeRTOS的API很多都是带参宏,所以跳来跳去的比较麻烦,而且注释也很多 ...

  9. B-线性代数-矩阵转置

    [TOC] 更新.更全的<机器学习>的更新网站,更有python.go.数据结构与算法.爬虫.人工智能教学等着你:https://www.cnblogs.com/nickchen121/ ...

  10. 【Java 基础】你听说过JMX么

    目录 什么是JMX 相关概念 MBean代码示例 MBean本地连接 MBean远程连接 通过Spring发布MBean 消息订阅发布 参考 什么是JMX JMX(Java管理扩展),是一套给应用程序 ...