- 备份
-
- 停机拷贝
- mongodump/mongorestore
- fsync
> use admin
> db.runCommand({"fsync":1,"lock":1})
{
"info" : "now locked against writes, use db.fsyncUnlock() to unlock",
"seeAlso" : "http://dochub.mongodb.org/core/fsynccommand",
"ok" : 1
}
锁定后所有对数据库的写操作全部被会阻塞,读取操作不会受影响,此时可以进行文件拷贝进行备份,完成后执行
> db.$cmd.sys.unlock.findOne();
{ "ok" : 1, "info" : "unlock requested" }
> db.currentOp();
{ "inprog" : [ ] }
解锁,写入正常。
未正常停止重后启应该修复,使用--repair参数进行启动
运行中数据库的修复,db.repairDatabase(),使用程序{"repairDatabase":1}
新版本已经不在推荐,
副本集没有主从节点之分,在同一时间多个节点总有一个活跃节点和多个备份节点,当其中一个节点出故障时,有其它的节点会自动升为活跃节点。
test环境复制集部署
- 创建不同的实例目录
mkdir -p /data/rs/rs0-0 /data/rs/rs0-1 /data/rs/rs0-2
- 分别带参数启动实例rs.initiate()
./mongod --port 27017 --dbpath /data/rs/rs0-0 --replSet rs0
./mongod --port 27018 --dbpath /data/rs/rs0-1 --replSet rs0
./mongod --port 27019 --dbpath /data/rs/rs0-2 --replSet rs0
注意:操作系统主机名一定要在/etc/hosts里加入对应的配置,否则下面的操作会报错
- 初始化主复制
使用mongo连接到其中一个实例,执行
rs.initiate()
查看一下状态
rs.status()
加入其它成员
rs.add("host:27018")
rs.add("host:27019")
查看状态
- 测试
在此时,只有一个是活动节点,其它是备份节点,在活动节点执行db.test.insert({"x":1}),但是此的备份节点是不能读写的,连接其中备份节点,执行
db.slaveOk(),然后执行db.test.find(),刚才插入的文档能找出来,ok,基本完成。
mkdir -p /data/rs/rs0-3
./mongod --port 27020 --dbpath /data/rs/rs0-3 --replSet rs0
mongo 连接到活动节点
rs.add("host:27020")
rs.status(),直接到同步完成
通过数据库快照(--fastsync)和 和和 和oplog增加节点
cp -r /data/rs/r0-3 /data/rs0-4(注意,需要在停止服务的时候进行复制)
./mongod --port 27021 --dbpath /data/rs/rs0-4 --replSet rs0
mongo 连接到活动节点
rs.add("host:27020")
rs.status(),直接到同步完成
登录到活动节点,执行rs.remove("host:port"),然后使用rs.status()查看复制集状态
分享到:
相关推荐
mongodb学习笔记资料,从安装到操作库collection 对document的crud 索引 replicaSet sharding 备份与恢复
自己在学习MongoDB的一些笔记,里面有各个查询选择器的使用截图,还有一些索引的介绍。
MongoDB 学习笔记 本文档是 MongoDB 学习笔记,涵盖了 NoSQL、Cache、运行平台等多个方面的知识点。 一、NoSQL 数据库 MongoDB MongoDB 是一个强大、灵活、可扩展性好的文档数据存储器,可以完成大部分关系数据库...
本篇学习笔记将从基础操作到高级功能,详细阐述MongoDB的关键知识点。 首先,MongoDB的基本单元是集合(collection),类似于关系型数据库中的表,而集合中的元素称为文档(document),文档是键值对的集合,类似于...
mongodb学习笔记 MongoDB 是一个基于分布式文件存储的开源数据库系统,主要用于处理大量数据的存储和查询。以下是 MongoDB 的一些基本操作和技巧: 插入文档 MongoDB 中可以使用 `insert` 方法来插入文档,例如 ...
首先,`mongodb_and_python`学习笔记可能涵盖了如何使用Python编程语言与MongoDB进行交互。Python是常见的MongoDB驱动程序之一,通过PyMongo库,开发者可以方便地执行CRUD(创建、读取、更新、删除)操作,构建复杂...
总结的MongoDB的学习笔记,基本上包括了MongoDB的方方面面,每个知识点,都有示例代码,有需要的朋友,可以下载下来进一步补充完善。
MongoDB 是一种流行的开源、非关系型数据库系统,以其灵活性、高性能和易用性而备受开发者青睐。在本文中,我们将深入探讨 ...在实际项目中,学习和掌握 MongoDB 及其驱动程序能够帮助你更好地应对现代数据存储需求。
本压缩包“mongoDB学习笔记及工具.zip”包含了一些资源,帮助你深入理解和掌握MongoDB的相关知识。 1. **笔记(note.txt)**: 这个文件可能是对MongoDB的基础概念、安装过程、基本操作和进阶特性的详细记录。笔记...
MongoDB是一种流行的NoSQL数据库,它的索引机制与传统的关系型数据库类似,旨在提升查询和排序的速度。在MongoDB中,索引对于优化查询性能至关重要,尤其在处理大量数据时。下面将详细介绍MongoDB中不同类型的索引...
### MongoDB 学习笔记知识点详解 #### 一、MongoDB 命令行基础操作 **1.1 帮助命令** - **help**:显示 MongoDB shell 的基本帮助信息。 - **db.help()**:提供当前数据库的帮助信息。 - **db.mycoll.help()**:...
`fs.chunks`集合则存储文件的实际数据,每个chunk对应一条记录,包含文件ID(`files_id`)、chunk编号(`n`)以及二进制数据(`data`)。默认情况下,chunk的大小为256KB。当文件大小超过chunk大小时,文件会被自动分割成...
以下是对MongoDB学习的一些关键知识点的详细解释: 1. **MongoDB的基本概念**:MongoDB以集合(Collections)的形式存储数据,集合相当于关系型数据库中的表。集合内包含文档(Documents),文档是JSON格式的数据...
MongoDB最详细学习笔记