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

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”});

  

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

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

  

  

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

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

  

  

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

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

豆包爱学 豆包爱学

豆包旗下AI学习应用

豆包爱学 674 查看详情 豆包爱学

  

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

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

   

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

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

  

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

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

  

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

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

  

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

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

  

   

  

,美国服务器

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/472329.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 08:04:02
下一篇 2025年11月8日 08:08:34

相关推荐

  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 解析基于元素位置的固定定位原理

    固定定位:基于元素位置的固定定位原理解析,需要具体代码示例 如果你在网页设计或开发中曾经需要固定某个元素的位置,那么你就会用到CSS中的固定定位(position:fixed)。固定定位是一种可以将元素固定在页面的特定位置的CSS布局技术。在本文中,我们将深入探讨固定定位的原理,并提供一些具体的代码…

    2025年12月24日
    000
  • 研究绝对定位概念和原理的深入分析

    绝对定位:一种精确控制元素位置的CSS属性 引言:在网页设计中,精确控制元素位置是非常重要的。而绝对定位是CSS中一种非常便捷的方法来实现这一目标。绝对定位可以让我们将元素从正常的文档流中脱离出来,并且以自定义的位置进行放置。本文将深入解析绝对定位的概念和原理,并给出具体的代码示例,以帮助读者更好地…

    2025年12月24日
    000
  • 深入理解CSS中绝对定位的机制以及其在网页布局中的优点

    探索绝对定位属性CSS的原理及其在网页布局中的优势 在网页设计和开发中,定位元素是一个非常重要的概念。其中,绝对定位是一种常用的定位方式,它可以让我们更精确地控制元素在页面中的位置和布局。本文将探索绝对定位属性CSS的原理,并介绍它在网页布局中的优势。同时,还将提供一些具体的代码示例。 首先,我们来…

    2025年12月24日
    000
  • 零基础学习如何快速掌握CSS框架:快速入门指南

    CSS框架快速入门指南:从零开始学习如何快速做好CSS框架,需要具体代码示例 引言:在当今的Web开发中,CSS框架被广泛应用于构建漂亮、响应式的网页设计。CSS框架可以帮助开发者快速搭建美观、一致的网页布局,减少开发时间。本文将介绍如何从零开始学习并掌握使用CSS框架,以及提供具体的代码示例。 一…

    2025年12月24日
    000
  • 了解id选择器的语法规则

    探索id选择器的语法原理,需要具体代码示例 CSS 是一种用于网页样式设计的语言,它强大而灵活,使我们能够通过样式表来改变网页的外观和布局。在 CSS 中,选择器是一种用于选择网页元素的模式。其中,id 选择器是一种非常重要且常用的选择器。本文将深入探索 id 选择器的语法原理,并提供具体的代码示例…

    2025年12月24日
    000
  • 从零开始学习CSS3:逐步掌握核心技术

    从零开始学习CSS3:逐步掌握核心技术 CSS(层叠样式表)是网页设计中不可或缺的一部分,它决定了网页的外观和布局。随着互联网的发展,CSS也不断更新,其中最新版本为CSS3。CSS3引入了许多新的特性和功能,提供更多的设计选择和更丰富的用户体验。本文将介绍如何从零开始学习CSS3,掌握其核心技术。…

    2025年12月24日
    000
  • CSS3的学习轨迹和常见误区解析

    CSS3的学习轨迹和常见误区解析 引言:随着Web技术的不断发展,CSS3已经成为了前端工程师必备的技能之一。通过掌握CSS3的各种功能和特效,我们能够创建出更加丰富多彩的网页布局和交互效果。本文将介绍CSS3的学习轨迹,同时分析一些常见的误区,并提供一些代码示例。 一、学习轨迹: 1.掌握基本语法…

    2025年12月24日
    000
  • css清除浮动的原理介绍

    首先我们要知道clear:both是清除浮动的关键。 (推荐教程:css快速入门) clear是CSS中的定位属性,规定元素的哪一侧不允许其他浮动元素。那么clear:both就是规定在左右两侧均不允许浮动元素。 clear属性只能在块级元素上其作用,这就是清除浮动样式中display:block的…

    2025年12月24日 好文分享
    000
  • Dw中不用CSS样式为表格添加细线边框的方法

    这篇文章主要介绍了关于dw中不用css样式为表格添加细线边框的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 用CSS添加细线可以.不用也可以.本文就是介绍不用CSS也给表格添加细线的方法 近段时间在学习Dreamweaver做网站,正在学表格这一章呢,结果发现表格的边框设置非常…

    2025年12月24日 好文分享
    000
  • html如何存储_使用Web Storage等存储HTML页面数据【数据】

    可在浏览器中用Web Storage API持久化保存HTML数据:一、localStorage永久存键值对;二、sessionStorage暂存标签页级数据;三、存取HTML字符串片段;四、IndexedDB存复杂结构化数据;五、结合data-*属性批量序列化表单。 如果需要在浏览器中持久化保存H…

    2025年12月23日
    000
  • html5发现错误调试_浏览器开发者工具调试技巧【详解】

    HTML5 页面问题可通过浏览器开发者工具高效调试:Console捕获错误,Elements检查结构样式,Sources设置断点,Network诊断资源加载,Application管理存储与PWA配置。 如果您在开发 HTML5 页面时遇到功能异常、样式错乱或脚本不执行等问题,很可能是由于代码语法错…

    2025年12月23日
    000
  • 如何添加HTML首页跳转_主页自动重定向设置【教程】

    可通过四种方式实现网站根目录自动跳转:一、meta标签客户端跳转;二、JavaScript动态跳转;三、HTTP重定向响应头服务端跳转;四、HTML5 history.replaceState单页应用跳转。 如果您希望用户访问网站根目录时自动跳转到指定的首页或主页,可以通过HTML代码实现页面重定向…

    2025年12月23日
    000
  • 怎么在手机运行html_手机运行html方法【教程】

    手机可直接通过浏览器打开本地HTML文件预览,或使用专用编辑器如Acode实现编辑与实时渲染,亦可通过电脑搭建局域网服务器让手机访问测试网页效果。 如果您在手机上编写或接收了一个HTML文件,但无法直接查看其网页效果,可能是因为手机默认没有启用HTML解析功能。以下是几种在手机上运行HTML文件的方…

    2025年12月23日
    000
  • html5如何添加歌曲_HTML5添加歌曲步骤与音频嵌入技巧【详解】

    HTML5通过标签实现原生音频播放,支持controls、autoplay、loop等属性;可用提供多格式备选;可隐藏控件用JS自定义控制;preload优化加载策略;跨域资源需配置CORS。 如果您希望在网页中嵌入音频文件并实现歌曲播放功能,HTML5 提供了原生的 元素,无需依赖第三方插件即可完…

    2025年12月23日
    000
  • 将HTML表单数据写入服务器文件:PHP实现与常见部署问题排查

    本文详细介绍了如何使用php处理html表单提交的数据并将其写入服务器上的配置文件。我们将探讨前端html表单的结构、后端php脚本实现文件写入的逻辑,并通过实际代码示例进行说明。此外,文章还重点讲解了在实际部署中可能遇到的常见问题,特别是nginx与php-fpm之间通信配置不匹配导致的错误,并提…

    2025年12月23日
    000
  • html5如何建立网站_使用HTML5构建静态网站完整步骤【建站指南】

    使用HTML5从零搭建静态网站需完成五步:一、创建含语义化标签的标准HTML5结构;二、用nav、section、article等标签组织布局;三、外链CSS实现样式分离;四、嵌入本地图片与mailto链接增强表现;五、通过本地服务器预览并W3C验证。 如果您希望使用HTML5从零开始搭建一个静态网…

    2025年12月23日
    000
  • Angular应用编译过程中注释处理机制与优化

    本文详细阐述angular应用在编译过程中对html和typescript代码注释的处理策略。默认情况下,注释不会被移除。对于html注释,可通过生产模式构建(`ng build –prod`)实现删除;而typescript注释的移除,则需在`tsconfig.json`中配置`rem…

    2025年12月23日
    000
  • 使用HTML表单GET方法创建带查询参数的动态搜索链接

    本教程详细阐述了如何在网页中,通过简单地将HTML表单的提交方法从`POST`更改为`GET`,来自动生成包含用户选择搜索条件的动态URL查询参数。这使得搜索结果页面的链接可分享、可收藏,并简化了%ignore_a_1%生成复杂URL的逻辑,后端可直接从URL中解析查询参数进行数据检索。 引言:动态…

    2025年12月23日
    000
  • Web表单提交:如何利用GET方法构建动态查询链接

    本文将指导您如何利用html表单的get方法,根据用户输入的搜索条件动态生成带有查询参数的url。当用户在表单中输入数据并提交时,get方法会自动将表单字段及其值附加到url作为查询字符串,从而创建如`/search?param1=value1&param2=value2`的链接。这对于实现…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信