- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Mongodb 删除添加分片与非分片表维护由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案.
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.
1、如何移除分片 。
1、确认balancer已经开启 。
mongos> sh.getBalancerState() true 。
2、移除分片 。
注:在admin db下执行命令.
1
2
3
4
5
6
7
8
9
|
mongos> use admin
switched
to
db admin
mongos> db.runCommand( { removeShard:
"shard3"
} )
{
"msg"
:
"draining started successfully"
,
"state"
:
"started"
,
"shard"
:
"shard3"
,
"ok"
: 1
}
|
3、检查迁移的状态 。
同样执行 。
1
2
3
4
5
6
7
8
9
10
11
12
|
mongos> use admin
switched
to
db admin
mongos> db.runCommand( { removeShard:
"shard3"
} )
{
"msg"
:
"draining ongoing"
,
"state"
:
"ongoing"
,
"remaining"
: {
"chunks"
: NumberLong(3),
"dbs"
: NumberLong(0)
},
"ok"
: 1
}
|
remaining中的chunks表示还有多少数据块未迁移.
4、移除未分片数据 。
In a cluster, a database with unsharded collections stores those collections only on a single shard. That shard becomes the primary shard for that database. (Different databases in a cluster can have different primary shards.) WARNING Do not perform this procedure until you have finished draining the shard. 1)To determine if the shard you are removing is the primary shard for any of the cluster's databases, issue one of the following methods: sh.status() db.printShardingStatus() In the resulting document, the databases field lists each database and its primary shard. For example, the following database field shows that the products database uses mongodb0 as the primary shard: { "_id" : "products", "partitioned" : true, "primary" : "mongodb0" } 2)To move a database to another shard, use the movePrimary command. For example, to migrate all remaining unsharded data from mongodb0 to mongodb1, issue the following command: use admin db.runCommand( { movePrimary: "products", to: "mongodb1" }) --products为db name This command does not return until MongoDB completes moving all data, which may take a long time. The response from this command will resemble the following: { "primary" : "mongodb1", "ok" : 1 } If you use the movePrimary command to move un-sharded collections, you must either restart all mongos instances, or use the flushRouterConfig command on all mongos instances before writing any data to the cluster. This action notifies the mongos of the new shard for the database. If you do not update the mongos instances' metadata cache after using movePrimary, the mongos may not write data to the correct shard. To recover, you must manually intervene. 。
根据上面所说,迁移非分片表 时 最好停机,在运行db.runCommand( { movePrimary: "products", to: "mongodb1" }) 命令完成之后,刷新所有mongos后(所有mongos上运行db.runCommand("flushRouterConfig")),再对外提供服务。当然也可以重新启动所有mongos实例 .
5、完成迁移 。
1
2
3
4
5
6
7
8
9
|
mongos> use admin
switched
to
db admin
mongos> db.runCommand( { removeShard:
"shard3"
} )
{
"msg"
:
"removeshard completed successfully"
,
"state"
:
"completed"
,
"shard"
:
"shard3"
,
"ok"
: 1
}
|
如果state为 completed,表示已完成迁移.
2、添加分片 。
1、首先确认balancer已经开启 。
mongos> sh.getBalancerState() true 。
2、执行添加分片的命令 。
如果出现以下错误,删除目标shard3上的test1数据库,再次执行命令 。
1
2
3
4
5
6
7
|
mongos> sh.addShard(
"shard3/192.168.137.138:27019"
)
{
"ok"
: 0,
"errmsg"
:
"can't add shard shard3/192.168.137.138:27019 because a local database 'test1' exists in another shard1:shard1/192.168.137.111:27017,192.168.137.75:27017"
}
mongos> sh.addShard(
"shard3/192.168.137.138:27019"
)
{
"shardAdded"
:
"shard3"
,
"ok"
: 1 }
|
最后运行sh.status()命令确认迁移是否成功,可能会花比较长的时间.
以上内容是给大家介绍了Mongodb 删除添加分片与非分片表维护的全部叙述,希望对大家有所帮助.
最后此篇关于Mongodb 删除添加分片与非分片表维护的文章就讲到这里了,如果你想了解更多关于Mongodb 删除添加分片与非分片表维护的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!