• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mongodb sharding 原理学习与试用(五)之添加与移除shard

mongodb sharding 原理学习与试用(五)之添加与移除shard

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了mongodb,sharding,原理,学习,试用,添加,s等相关知识,希望本文的分享对您有所帮助

1. 今天上午遇到一个有关host设置一部分是localhost另一部分是hostname,造成向sharding添加shard的时候失败。特纪录下来。 问题:一个已存在的sharding各个shard都是本机的其他的mongod进程,在当初添加shard的时候,db.runCommand({addshard:"localhost:po

1. 今天上午遇到一个有关host设置一部分是localhost另一部分是hostname,网站空间,造成向sharding添加shard的时候失败。特纪录下来。

  问题:一个已存在的sharding各个shard都是本机的其他的mongod进程,在当初添加shard的时候,db.runCommand({addshard:"localhost:port"})。后来又在本机配置了一个replSet.问题就来了。replSet布署成功后,其中的各个节点的host使用的是hostname.这样一来,当我将replSet添加到sharding的时候报错。因为sharding的各个节点如果都是本机的其他进程的话,在设置host的时候要么全部使用localhost要么全部使用hostname,如果混用会报错。

  解决过程:刚开始我打算将replSet的各个节点的host改成localhost.但是在reconfig的时候报错。报错截图如下:

  

  之后考虑将已经添加到sharding中各个shard的host改成hostname.修改方法是use config;db.shards.update({_id:xx},{host:"xx"});这回修改成功了。之后就简单了。

2. 从sharding当中移除一个shard。需要将存储在将被移除的shard中数据移到其他的shard中。移除完成后,被移除的shard就没有数据了。

  (一)移除一个shard. use admin; db.runCommand({removeshard:"name"});

  

  (二)执行结果如上图,需要注意的是,note有提示说需要执行movePrimary操作。这是因为被移除的shard是某几个库的大本营。如果是这种情况,就需要在数据移除完之后执行movePrimary操作,为这几个库设置新的大本营。需要设置新的大本营的几个库这里也已经给出来了,例如dbsToMove的值 。如果被移除的shard不存在是任何一个库的大本营,那么就不需要执行movePrimary.如下图

  

  

  (三)如上图,名为shard0001的shard并不是哪个库的大本营,因此在被移除的时候,结果输出中并没有类似于移除shard0000的时候有note与dbsToMove这两个值。需要注意的是,被移除的shard是某几个库的大本营,不管是否有库不参加分片,都需要为库设置新的大本营。如下图

  

  

  (四)在数据迁移之前sar的partitioned的值是false,迁移完成执行movePrimary操作后,sar的partitioned的值仍是false.如下图。

  

  (五)在移除数据过程中,由于网络与数据量的原因,可能需要花费不同的时间。执行db.runCommand({removeshard:"name"})命令可以查看数据迁移的进度。

   

  (六)如上图,通过执行db.runCommand({removeshard:"name"})命令不但可以开始移除shard,还可以在移除的过程中查看数据迁移的进度。remaining的值就表示数据迁移的进度。其中chunks代表还剩多少块数据需要被迁移。当chunks的值等于0时代表数据迁移完成。dbs的值代表还剩多少个库需要设置新的大本营。movePrimary操作要等到数据迁移完成之后再进行。也就是当chunks的值等于0后才可以执行movePrimary操作。

  

  (七)如上图,chunks的值等于0代表数据迁移已经完成。可以开始movePrimary操作。

  

  (八)如上图,将库foo,too重新设置大本营为rs0这个shard.操作完成后,香港虚拟主机,可以查看整个移除进度了。

  

  (九)如上图,代表整个移除过程已经全部完成。这个时候就可以放心的停掉shard0000这个shard了。

  

   

  

,美国服务器
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MongoDB中常用的语句总结
  • MongoDB导入json数据的方法
  • MongoDB提升性能的方法总结
  • 什么是MongoDB?MongoDB简介
  • 什么是mongoDB数据库
  • 黑马云课堂mongodb实操视频的源码课件推荐
  • 燕十八mongodb视频资料分享
  • 分享用MongoDB中oplog机制实现数据监控实例
  • 详细介绍MongoDB常用的操作
  • mongoDB是怎么实现分页的?

相关文章

  • 2018-12-05六天带你玩转MySQL视频教程资源推荐
  • 2018-12-05Oracle9iPL/SQL编程的经验小结
  • 2018-12-05网上提供的最简便的MySql数据库备份的方法
  • 2018-12-05教你几种在SQLServer中删除重复数据方法
  • 2018-12-05SQL语句中on和where的用法区别讲解
  • 2018-12-05SQLServer APPLY表运算符使用介绍
  • 2018-12-05SQL2008中SQL应用之-锁定(locking) 应用分析
  • 2018-12-05SQLServer 数据库的数据汇总完全解析(WITH ROLLUP)
  • 2018-12-05批量替换sqlserver数据库挂马字段并防范sql注入攻击的代码
  • 2018-12-05使MySQL查询区分大小写的实现方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MYSQL面试题(一)
    • SQL Server 7.0 入门(一)
    • PHP运算符与操作符入门详解
    • 关于库配置的10篇文章推荐
    • 浅析Oracle 11g中对数据列默认值变化的优化
    • 在Oracle数据库上设置限制ip地址访问以及需要注意的事项
    • MySQL之-MySQL使用遇到的相关问题解析
    • 更改SQL Server更改当前数据库的所有者:sp_changedbowner
    • Spring Boot添加MySQL数据库及JPA实例的示例代码分享
    • 解析MySQL数据库性能优化的六大技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有