• 售前

  • 售后

热门帖子
入门百科

MongoDB balancer的使用详解

[复制链接]
刘冠华 显示全部楼层 发表于 2021-8-14 15:06:06 |阅读模式 打印 上一主题 下一主题
目次


  • 01 balancer简介
  • 02 balancer工作中大概对业务造成的影响?
  • 03 设置balancer的执行时间窗口
  • 04 备份和balancer
   在MongoDB中,balancer(平衡器)是一个背景进程,它监控每个shard上的chunk数量,一旦chunk的数量差别超过了阈值,balancer会主动迁徙数据块,从而保证每个分片上chunk数量的相对平衡。
   整个搬迁的过程对于用户来说是透明的,但是搬迁的过程中会对用户产生一些影响。

01 balancer简介

   从MongoDB3.4开始,balancer运行在config server的主节点上。
    在3.4版本中,balancer进程生动期间,config server的主节点通过修改locks集合中的一个_id为balancer的文档,来持有"balancer lock";
    3.6版本中,balancer不再持有锁
    默认的环境下,balancer始终处于开启状态,可以使用下面的下令来查察balancer的运行环境:
  1. mongos> sh.getBalancerState()
  2. true
复制代码
   同样的,我们可以使用下面几个下令来简单的管理balancer:
  1. 查看banlancer是否正在工作
  2. sh.isBalancerRunning() 
  3. 停止balancer
  4. sh.stopBalancer()
  5. 启动balancer
  6. sh.setBalancerState( true )
复制代码
02 balancer工作中大概对业务造成的影响?

1、磁盘占用:
   从MongoDB2.6开始,MongoDB会主动归档迁徙的chunk文档,以方便在chunk搬迁过程中出现题目后的文档恢复。
   我们可以通过配置文件中的参数:sharding.archiveMovedChunks
来控制是否开启迁徙过程中chunk的主动归档,该参数在MongoDB2.6和3.0版本是默认开启的,其他版本都是默认关闭的。
2、带宽和负载占用:
    balancer再对chunk迁徙过程中,会造成带宽和负载方面的开销。为了减轻这些影响,平衡器做了如下的工作:
a、一次迁徙只能迁一个chunk,
b、一个shard同一时间只能执行一个迁徙使命
c、从MongoDB3.4开始,引入了并行的chunk迁徙,对于一个有n个shard的集群,每次最多并行迁徙n/2(向下取整)个数据块
d、只有当chunk数量最多的shard和chunk数量最少的shard的差别到达阈值的时候,才开始迁徙chunk
e、支持用户设置balancer的窗口时间,在业务低峰窗口时间内举行chunk的迁徙工作,从而最大水平减轻对业务的影响。

03 设置balancer的执行时间窗口

1、通过mongo shell连接到mongos上
2、切换到config数据库
    use config
3、确保当前balancer是开启的
    sh.getBalancerState()  返回true
4、设置窗口时间
  1. db.settings.update(
  2.    { _id: "balancer" },
  3.    { $set: { activeWindow : { start : "<start-time>", stop : "<stop-time>" } } },
  4.    { upsert: true }
  5. )
复制代码
此中,start-time和stop-time的取值如下:
       
  • For HH values, use hour values ranging from 00 - 23.   
  • For MM value, use minute values ranging from 00 - 59.
MongoDb会以config数据库的primary节点的时间为参考,开始执行相关chunk的搬迁利用。
要确保设置的时间范围内,全部的chunk可以或许搬迁完毕,否则会出现数据库搬迁过后,仍然不平衡的征象。
移除chunk搬迁时间窗口的下令如下:
  1. use config
  2. db.settings.update({ _id : "balancer" }, { $unset : { activeWindow : true } })
复制代码
04 备份和balancer

   MongoDB中,不要在备份的时候启用balancer,否则,备份的数据将会差别等。通常环境下,备份的时间窗口要和balancer的时间窗口错开,假如balancer没有设置时间窗口,则在备份的时候,关闭balancer
   时间关系,就先到这里吧,其他内容后面再说
以上就是MongoDB balancer的使用详解的详细内容,更多关于MongoDB balancer的使用的资料请关注脚本之家别的相关文章!

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作