`

Mongodb学习笔记(二)

 
阅读更多

 

  • 备份
    • 停机拷贝
    • 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}
  • 复制
    • 主从复制
                    新版本已经不在推荐,
    •   复制集(Replica Sets)
                      副本集没有主从节点之分,在同一时间多个节点总有一个活跃节点和多个备份节点,当其中一个节点出故障时,有其它的节点会自动升为活跃节点。
                      
              test环境复制集部署
      1. 创建不同的实例目录
                              mkdir -p /data/rs/rs0-0 /data/rs/rs0-1 /data/rs/rs0-2
      1. 分别带参数启动实例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里加入对应的配置,否则下面的操作会报错
      1. 初始化主复制
                               使用mongo连接到其中一个实例,执行
                               rs.initiate()
                               查看一下状态
                               rs.status()
                               加入其它成员
                               rs.add("host:27018")
                               rs.add("host:27019")
                               查看状态                                  
      1. 测试
                                在此时,只有一个是活动节点,其它是备份节点,在活动节点执行db.test.insert({"x":1}),但是此的备份节点是不能读写的,连接其中备份节点,执行
            db.slaveOk(),然后执行db.test.find(),刚才插入的文档能找出来,ok,基本完成。

                         
  • 增加节点
                         通过oplog增加节点 
                                   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学习笔记资料

    mongodb学习笔记资料,从安装到操作库collection 对document的crud 索引 replicaSet sharding 备份与恢复

    MongoDB学习笔记

    自己在学习MongoDB的一些笔记,里面有各个查询选择器的使用截图,还有一些索引的介绍。

    Mongodb学习笔记.docx

    MongoDB 学习笔记 本文档是 MongoDB 学习笔记,涵盖了 NoSQL、Cache、运行平台等多个方面的知识点。 一、NoSQL 数据库 MongoDB MongoDB 是一个强大、灵活、可扩展性好的文档数据存储器,可以完成大部分关系数据库...

    MongoDB学习笔记思维导图.pdf

    本篇学习笔记将从基础操作到高级功能,详细阐述MongoDB的关键知识点。 首先,MongoDB的基本单元是集合(collection),类似于关系型数据库中的表,而集合中的元素称为文档(document),文档是键值对的集合,类似于...

    mongodb学习笔记

    mongodb学习笔记 MongoDB 是一个基于分布式文件存储的开源数据库系统,主要用于处理大量数据的存储和查询。以下是 MongoDB 的一些基本操作和技巧: 插入文档 MongoDB 中可以使用 `insert` 方法来插入文档,例如 ...

    mongodb学习笔记和mongodb权威指南

    首先,`mongodb_and_python`学习笔记可能涵盖了如何使用Python编程语言与MongoDB进行交互。Python是常见的MongoDB驱动程序之一,通过PyMongo库,开发者可以方便地执行CRUD(创建、读取、更新、删除)操作,构建复杂...

    MongoDB学习笔记思维导图

    总结的MongoDB的学习笔记,基本上包括了MongoDB的方方面面,每个知识点,都有示例代码,有需要的朋友,可以下载下来进一步补充完善。

    MongoDB学习笔记1

    MongoDB 是一种流行的开源、非关系型数据库系统,以其灵活性、高性能和易用性而备受开发者青睐。在本文中,我们将深入探讨 ...在实际项目中,学习和掌握 MongoDB 及其驱动程序能够帮助你更好地应对现代数据存储需求。

    mongoDB学习笔记及工具.zip

    本压缩包“mongoDB学习笔记及工具.zip”包含了一些资源,帮助你深入理解和掌握MongoDB的相关知识。 1. **笔记(note.txt)**: 这个文件可能是对MongoDB的基础概念、安装过程、基本操作和进阶特性的详细记录。笔记...

    MongoDB学习笔记(六) MongoDB索引用法和效率分析

    MongoDB是一种流行的NoSQL数据库,它的索引机制与传统的关系型数据库类似,旨在提升查询和排序的速度。在MongoDB中,索引对于优化查询性能至关重要,尤其在处理大量数据时。下面将详细介绍MongoDB中不同类型的索引...

    MongoDB_学习笔记

    ### MongoDB 学习笔记知识点详解 #### 一、MongoDB 命令行基础操作 **1.1 帮助命令** - **help**:显示 MongoDB shell 的基本帮助信息。 - **db.help()**:提供当前数据库的帮助信息。 - **db.mycoll.help()**:...

    MongoDB学习笔记之GridFS使用介绍

    `fs.chunks`集合则存储文件的实际数据,每个chunk对应一条记录,包含文件ID(`files_id`)、chunk编号(`n`)以及二进制数据(`data`)。默认情况下,chunk的大小为256KB。当文件大小超过chunk大小时,文件会被自动分割成...

    MongoDB学习总结笔记

    以下是对MongoDB学习的一些关键知识点的详细解释: 1. **MongoDB的基本概念**:MongoDB以集合(Collections)的形式存储数据,集合相当于关系型数据库中的表。集合内包含文档(Documents),文档是JSON格式的数据...

    MongoDB最详细学习笔记.txt

    MongoDB最详细学习笔记

Global site tag (gtag.js) - Google Analytics