mongodb 常见问题

本文分两部分介绍mongodb3.2.1分片部署配置及故障模拟验证。

第一部分  安装配置

一、实验环境

两组副本集做分片

版本3.2.1

副本集1:192.168.115.11:27017,192.168.115.12:27017,192.168.115.11:47017(arbiter)

副本集2:192.168.115.11:37017,192.168.115.12:37017,192.168.115.12:47017(arbiter)

configserver:192.168.115.11:10000,192.168.115.11:10001,192.168.115.12:10000

mongos:192.168.115.11:20000

二、分片介绍

1.逻辑图

片(shard):每一个分片一个副本集

配置服务器(config server):存储集群的配置信息,3.2以上版本支持副本集模式部署

路由进程(mongos):路由所有请求,然后将结果聚合。它不保存存储数据或配置信息,配置信息从配置服务器上加载到内存中。

副本集方式部署confiserver

一、部署条件

1.集群中不能有仲裁节点

2.集群中不能有延迟节点

3.每个成员必须可以创建索引

二、configserver安装配置

1.修改配置文件(其他两个节点配置文件类似,主要修改监听端口,及数据路径,如果一台机器上运行多个实例,注意配置文件名称要不一样)

cat config.conf

fork = true

quiet = true

port = 10000

dbpath = /data/config

logpath = /usr/local/mongodb/logs/config.log

logappend = true

directoryperdb = true

configsvr = true

replSet = hnrconfig/192.168.115.11:10000,192.168.115.11:10001,192.168.115.12:10000


2.服务启动和停止

/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/config.conf

 /usr/local/mongodb/bin/mongod --shutdown --port 10000 --dbpath=/data/config

3.配置副本集

连接任意一个节点进行配置

> show dbs

2016-11-17T09:06:08.088+0800 E QUERY    [thread1] Error: listDatabases failed:{ "ok" : 0, "errmsg" : "not master and slaveOk=false", "code" : 13435 } :

_getErrorWithCode@src/mongo/shell/utils.js:23:13

Mongo.prototype.getDBs@src/mongo/shell/mongo.js:53:1

shellHelper.show@src/mongo/shell/utils.js:700:19

shellHelper@src/mongo/shell/utils.js:594:15

@(shellhelp2):1:1

出现以上错误,需要执行

> rs.slaveOk()

> use admin

> db.runCommand({"replSetInitiate" : { "_id" : "hnrconfig" ,"members" : [ { "_id" : 1, "host" : "192.168.115.11:10000"},{ "_id" : 2, "host" : "192.168.115.12:10000"},{"_id" : 3, "host" : "192.168.115.11:10001"}]}})

{ "ok" : 1 }

三、mongos配置

1.配置文件

cat mongos.conf

fork = true

quiet = true

port = 20000

logpath = /usr/local/mongodb/logs/mongos.log

logappend = true

configdb = 192.168.115.11:10000,192.168.115.11:10001,192.168.115.12:10000


2.启动mongos服务

/usr/local/mongodb/bin/mongos -f /usr/local/mongodb/etc/mongos.conf

四、往集群中添加分片

连接mongos

mongos> sh.addShard("hnrtest1/192.168.115.11:27017")

{ "shardAdded" : "hnrtest1", "ok" : 1 }

mongos>

mongos> sh.addShard("hnrtest2/192.168.115.12:37017")

{ "shardAdded" : "hnrtest2", "ok" : 1 }

mongos>

五、开启分片

1.先对数据库启用分片功能

mongos> sh.enableSharding("shardtest")

{ "ok" : 1 }

mongos>

2.对集合开启分片(自动分片建)

mongos> sh.shardCollection("shardtest.student",{"cre_id":1})

{ "collectionsharded" : "shardtest.student", "ok" : 1 }

mongos>

3.修改默认chunk大小(默认为64M),自动分片测试效果不好,需要插入大量数据,将其修改为1M

mongos> use config

mongos> db.settings.save({ "_id" : "chunksize", "value" : NumberLong(1) })

修改后对student2集合进行分片

mongos> sh.shardCollection("shardtest.student2",{"cre_id":1})

插入5万条数据

直接在后端分片副本集上查询

hnrtest2:PRIMARY> db.student2.find().count()

27081

hnrtest2:PRIMARY>

hnrtest1:PRIMARY> db.student2.find().count()

22918

hnrtest1:PRIMARY>

4.采用哈希分片

修改chunk为默认值64M

mongos> db.settings.save({ "_id" : "chunksize", "value" : NumberLong(64) })

student3集合在cre_id字段使用哈希分片

mongos> sh.shardCollection("shardtest.student3",{"cre_id":"hashed"})

{ "collectionsharded" : "shardtest.student3", "ok" : 1 }

mongos> sh.status()

 shardtest.student3

                        shard key: { "cre_id" : "hashed" }

                        unique: false

                        balancing: true

                        chunks:

                                hnrtest1        2

                                hnrtest2        2

                        { "cre_id" : { "$minKey" : 1 } } -->> { "cre_id" : NumberLong("-4611686018427387902") } on : hnrtest1 Timestamp(2, 2)

                        { "cre_id" : NumberLong("-4611686018427387902") } -->> { "cre_id" : NumberLong(0) } on : hnrtest1 Timestamp(2, 3)

                        { "cre_id" : NumberLong(0) } -->> { "cre_id" : NumberLong("4611686018427387902") } on : hnrtest2 Timestamp(2, 4)

                        { "cre_id" : NumberLong("4611686018427387902") } -->> { "cre_id" : { "$maxKey" : 1 } } on : hnrtest2 Timestamp(2, 5)

 

往student3插入1万条数据,在每个分片上查询

hnrtest1:PRIMARY> db.student3.find().count()

4952

hnrtest1:PRIMARY>

hnrtest2:PRIMARY> db.student3.find().count()

5047

hnrtest2:PRIMARY>

第二部分  故障模拟验证

一、模拟config服务副本集primary节点宕机

1.关闭服务

/usr/local/mongodb/bin/mongod --shutdown --port 10000 --dbpath=/data/config

2.副本集重新选举一个primary节点

3.读取数据,所有数据均正常返回

mongos> use shardtest

switched to db shardtest

mongos>

mongos> db.student.find().count()

99999

mongos> db.student2.find().count()

49999

mongos> db.student3.find().count()

9999

mongos>

4.对新的集合进行分片,插入5千条数据

mongos> sh.shardCollection("shardtest.student4",{"cre_id":"hashed"})

{ "collectionsharded" : "shardtest.student4", "ok" : 1 }

mongos>

在每个分片上查询数据

hnrtest2:PRIMARY> db.student4.find().count()

2525

hnrtest2:PRIMARY>

hnrtest1:PRIMARY> db.student4.find().count()

2474

hnrtest1:PRIMARY>

二、config服务数据备份恢复

1.数据备份

/usr/local/mongodb/bin/mongodump -h 192.168.115.11:10001 -o configdata

2.关闭所有config服务节点

/usr/local/mongodb/bin/mongod --shutdown --port 10000 --dbpath=/data/config

/usr/local/mongodb/bin/mongod --shutdown --port 10001 --dbpath=/data/config1

3.数据读取操作

由于mongos是将config的配置信息全部加载到内存中运行,因此此时通过mongos查询数据一切正常,但是不能对新的集合进行分片操作

mongos> db.student.find().count()

99999

mongos> db.student2.find().count()

49999

mongos> db.student3.find().count()

9999

mongos> db.student4.find().count()

4999

mongos>

4.对集合进行分片操作,无法完成

mongos> sh.shardCollection("shardtest.student5",{"cre_id":"hashed"})

{

        "ok" : 0,

        "errmsg" : "None of the hosts for replica set hnrconfig could be contacted.",

        "code" : 71

}

mongos>

5.关闭mongos服务,删除config节点所有数据

6.重新启动三个config服务

7.重新初始化副本集

> rs.slaveOk()

> use admin

> db.runCommand({"replSetInitiate" : { "_id" : "hnrconfig" ,"members" : [ { "_id" : 1, "host" : "192.168.115.11:10000"},{ "_id" : 2, "host" : "192.168.115.12:10000"},{"_id" : 3, "host" : "192.168.115.11:10001"}]}})

8.启动mongos服务,此时没有任何数据

9.导入备份的config数据

/usr/local/mongodb/bin/mongorestore -h 192.168.115.11:10000 -d config configdata/config/

在mongos查询,但是查询数据会出现超时,数据无法查询

10.在mongos执行如下命令

mongos> sh.enableSharding("shardtest")

{ "ok" : 0, "errmsg" : "Operation timed out", "code" : 50 }

mongos日志

2016-11-17T14:46:21.197+0800 I SHARDING [Balancer] about to log metadata event into actionlog: { _id: "node1.hnr.com-2016-11-17T14:46:21.197+0800-582d523ded1c4b679a84877b", server: "node1.hnr.com", clientAddr: "", time: new Date(1479365181197), what: "balancer.round", ns: "", details: { executionTimeMillis: 30007, errorOccured: true, errmsg: "could not get updated shard list from config server due to ExceededTimeLimit Operation timed out" } }

官网上说是bug,恢复失败

https://jira.mongodb.org/browse/SERVER-22392

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于 MongoDB 常见面试题,我可以为您提供以下问题和答案: 1. MongoDB 是什么?它与传统的关系型数据库有什么不同? 答:MongoDB 是一个开源的 NoSQL 数据库,它使用文档存储数据,而不是传统的表格。与关系型数据库相比,MongoDB 更加灵活,可以处理非结构化数据,并且具有更好的可扩展性和性能。 2. MongoDB 中的文档是什么?它们有哪些特点? 答:MongoDB 中的文档是一组键值对,类似于 JSON 对象。它们可以包含不同类型的值,如字符串、数字、日期、数组等。文档可以嵌套,这意味着一个文档可以包含另一个文档作为其值。文档还具有动态模式,这意味着不同的文档可以具有不同的字段。 3. MongoDB 中的集合是什么?它们与传统数据库中的表格有什么不同? 答:MongoDB 中的集合是一组文档,类似于关系型数据库中的表格。但是,与表格不同的是,集合中的文档可以具有不同的结构和字段。这使得 MongoDB 更加灵活,并且可以处理非结构化数据。 4. MongoDB 中的索引是什么?它们有什么作用? 答:MongoDB 中的索引是一种数据结构,用于加速查询操作。它们可以提高查询性能,并且可以帮助 MongoDB 在大型数据集上进行快速搜索。MongoDB 支持多种类型的索引,包括单字段索引、复合索引、全文索引等。 5. MongoDB 中的聚合管道是什么?它们有什么作用? 答:MongoDB 中的聚合管道是一种数据处理工具,用于对文档进行聚合操作。它们可以将多个操作组合在一起,以便在单个查询中执行多个操作。聚合管道可以用于数据分析、数据清洗、数据转换等多种场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值