在MongoDB数据库中配置shardreplicaconfig/分片复制
作者:小帅哥沈阳后援会果果 | 来源:互联网 | 2014-05-28 16:53
下面的配置是在同一台机器上的,我是在32位的xp下测试的,因为在32位的机器有2G数据大小的限制,数据量不会太大。这里配置两个replicaset,每个replicaset有三个shard,即三份数据。配置第一组:三个shard,同属于一个replicaset,即一份数据会有两个备
下面的配置是在同一台机器上的,我是在32位的xp下测试的,因为在32位的机器有2G数据大小的限制,数据量不会太大。
这里配置两个replica set,每个replica set有三个shard,即三份数据。
配置第一组:三个shard,同属于一个replica set,即一份数据会有两个备份数据和一个主数据,共三份
./bin/mongod --shardsvr --logpath ./logs/sharda.log --logappend
--dbpath ./data/a/r0 --port 10000 --rest --replSet set1 &
./bin/mongod --shardsvr --logpath ./logs/sharda.log --logappend
--dbpath ./data/a/r1 --port 10001 --rest --replSet set1 &
./bin/mongod --shardsvr --logpath ./logs/sharda.log --logappend
--dbpath ./data/a/r2 --port 10002 --rest --replSet set1 &
./bin/mongo --port 10000
cfg = {_id: 'set1', members:[
{_id: 0, host: 'localhost:10000'},
{_id: 1, host: 'localhost:10001'},
{_id: 2, host: 'localhost:10002'}]
}
rs.initiate(cfg);
rs.status()
配置第二组,三个shard,分别作为三个replica set
./bin/mongod --shardsvr --logpath ./logs/shardb.log --logappend
--dbpath ./data/b/r3 --port 10010 --rest --replSet set2 &
./bin/mongod --shardsvr --logpath ./logs/shardb.log --logappend
--dbpath ./data/b/r4 --port 10011 --rest --replSet set2 &
./bin/mongod --shardsvr --logpath ./logs/shardb.log --logappend
--dbpath ./data/b/r5 --port 10012 --rest --replSet set2 &
./bin/ mongo --port 10010
cfg = {_id: 'set2', members:[
{_id: 0, host: 'localhost:10010'},
{_id: 1, host: 'localhost:10011'},
{_id: 2, host: 'localhost:10012'}]
}
rs.initiate(config);
rs.status()
配置config server:
./bin/mongod --configsvr --dbpath ./data/config/ --port 20000
--rest --logpath /logs/config.log --logappend &
配置mongos route:
./bin/mongos --configdb localhost:20000 --chunkSize 10 --logpath
./logs/mongos.log --logappend &
配置shard:
use admin
db.runCommand({addshard:'set1/localhost:10000,localhost:10001,localhost:10002'})
db.runCommand({addshard:'set2/localhost:10010,localhost:10011,localhost:10013'})
db.runCommand({enablesharding:'crawler'})
db.runCommand({shardcollection:'crawler.videos', key:{_id:1}})
db.runCommand({listshards:1})
printShardingStatus()
另外可以进入其中一个shardsvr,查看replica set 的情况:
./bin/mongo --port 10000
rs.status() 命令会显示set的信息。
其中,health为1表明服务器正常,0表明服务器down了
state为1表明是Primary,2表明是Secondary,3是Recovering,7是Arbiter,8是Down
推荐阅读
-
本文介绍了如何使用Node.js通过两种不同的方法连接MongoDB数据库,包括使用MongoClient对象和连接字符串的方法。每种方法都有其特点和适用场景,适合不同需求的开发者。 ...
[详细]
蜡笔小新 2024-11-22 18:56:55
-
Asynchronous JavaScript and XML (AJAX) 的流行很大程度上得益于 Google 在其产品如 Google Suggest 和 Google Maps 中的应用。本文将深入探讨 AJAX 在 .NET 环境下的工作原理及其实现方法。 ...
[详细]
蜡笔小新 2024-11-22 18:18:57
-
-
本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ...
[详细]
蜡笔小新 2024-11-21 20:16:59
-
随着Linux操作系统的广泛使用,确保用户账户及系统安全变得尤为重要。用户密码的复杂性直接关系到系统的整体安全性。本文将详细介绍如何在CentOS服务器上自定义密码规则,以增强系统的安全性。 ...
[详细]
蜡笔小新 2024-11-22 19:15:42
-
规划部署虚拟桌面环境前,必须先估算目前所使用实体桌面环境的工作负载与IOPS性能,并慎选储存设备。唯有谨慎估算贴近实际的IOPS性能,才能 ...
[详细]
蜡笔小新 2024-11-22 19:12:09
-
本文详细介绍如何安装和配置DedeCMS的移动端站点,包括新版本安装、老版本升级、模板适配以及必要的代码修改,以确保移动站点的正常运行。 ...
[详细]
蜡笔小新 2024-11-22 18:44:25
-
黑客松获奖名单出炉、NFT艺术周圆满落幕 |Oasis周报 ...
[详细]
蜡笔小新 2024-11-22 18:23:40
-
本文详细介绍了JavaScript在不同域之间进行数据传输或通信的技术,包括使用JSONP、修改document.domain、利用window.name以及HTML5的postMessage方法等跨域解决方案。 ...
[详细]
蜡笔小新 2024-11-22 16:27:56
-
本文提供了多种有效的方法来解决RPC(远程过程调用)服务器不可用的问题,包括通过修改注册表、使用SC命令以及利用故障恢复控制台等技术手段。 ...
[详细]
蜡笔小新 2024-11-22 16:23:52
-
问题概述:在本地环境中代码运行正常,但部署到服务器后出现错误。具体表现为NCManager和SAXBuilder无法解析为类型。 ...
[详细]
蜡笔小新 2024-11-22 12:51:10
-
本文详细介绍了如何在CentOS 6.5系统上安装和配置Redis 3.0.6,包括必要的环境准备、软件包下载、编译安装及基本功能测试。 ...
[详细]
蜡笔小新 2024-11-22 11:42:46
-
本文详细介绍了Fiddler的安装步骤及配置方法,旨在帮助用户顺利抓取用户Token。文章还涵盖了一些常见问题的解决方案,以确保安装过程顺利。 ...
[详细]
蜡笔小新 2024-11-22 11:36:57
-
计划建立个人博客来分享生活与工作的见解和经验,选择WordPress是因为它专为博客设计,功能强大且易于使用。 ...
[详细]
蜡笔小新 2024-11-22 11:13:36
-
本文详细探讨了在Java TCP编程中,如何理解和测量并发连接数、请求数及并发用户数,并提供了实际应用中的测试方法和优化建议。 ...
[详细]
蜡笔小新 2024-11-22 11:06:05
-
本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ...
[详细]
蜡笔小新 2024-11-21 20:03:03
-
小帅哥沈阳后援会果果
这个家伙很懒,什么也没留下!