位置: 编程技术 - 正文

深入理解MongoDB分片的管理(深入理解计算机系统)

编辑:rootadmin

推荐整理分享深入理解MongoDB分片的管理(深入理解计算机系统),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入理解新发展理念,推进供给侧结构性改革 的题目,深入理解中国式现代化论文,深入理解两个大计重要论断心得体会,深入理解中国式现代化论文,深入理解中国式现代化,深入理解新发展理念,深入理解新发展理念,推进供给侧结构性改革,深入理解计算机系统,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

在MongoDB(版本 3.2.9)中,分片集群(sharded cluster)是一种水平扩展数据库系统性能的方法,能够将数据集分布式存储在不同的分片(shard)上,每个分片只保存数据集的一部分,MongoDB保证各个分片之间不会有重复的数据,所有分片保存的数据之和就是完整的数据集。分片集群将数据集分布式存储,能够将负载分摊到多个分片上,每个分片只负责读写一部分数据,充分利用了各个shard的系统资源,提高数据库系统的吞吐量。

数据集被拆分成数据块(chunk),每个数据块包含多个doc,数据块分布式存储在分片集群中。MongoDB负责追踪数据块在shard上的分布信息,每个分片存储哪些数据块,叫做分片的元数据,保存在config server上的数据库 config中,一般使用3台config server,所有config server中的config数据库必须完全相同。通过mongos能够直接访问数据库config,查看分片的元数据;mongo shell 提供 sh 辅助函数,能够安全地查看分片集群的元数据信息。

对任何一个shard进行查询,只会获取collection在当前分片上的数据子集,不是整个数据集。Application 只需要连接到mongos,对其进行的读写操作,mongos自动将读写请求路由到相应的shard。MongoDB通过mongos将分片的底层实现对Application透明,在Application看来,访问的是整个数据集。

一,主分片

在分片集群中,不是每个集合都会分布式存储,只有使用sh.shardCollection()显式将collection分片后,该集合才会分布式存储在不同的shard中。对于非分片集合(un-sharded collection),其数据只会存储在主分片(Primary shard)中,默认情况下,主分片是指数据库最初创建的shard,用于存储该数据库中非分片集合的数据。每个数据库都有一个主分片。

Each database in a sharded cluster has a primary shard that holds all the un-sharded collections for that database. Each database has its own primary shard.

例如,一个分片集群有三个分片:shard1,shard2,shard3,在分片shard1创建一个数据库blog。如果将数据库bolg分片,那么MongoDB会自动在shard2,shard3上创建一个结构相同的数据库blog,数据库blog的Primary Shard是Shard1。

图示,Collection2的主分片是ShardA。

使用 movePrimary命令变更数据库默认的Primary shard,非分片集合将会从当前shard移动到新的主分片。

在使用movePrimary命令变更数据库的主分片之后,config server中的配置信息是最新的,mongos缓存的配置信息变得过时了。MongoDB提供命令:flushRouterConfig 强制mongos从config server获取最新的配置信息,刷新mongos的缓存。

二,分片的元数据

不要直接到config server上查看分片集群的元数据信息,这些数据非常重要,安全的方式是通过mongos连接到config数据查看,或者使用sh辅助函数查看。

使用sh辅助函数查看

连接到mongos查看config数据库中的集合

1,shards 集合保存分片信息

shard的数据存储在host指定的 replica set 或 standalone mongod中。

2,databases集合保存分片集群中所有数据库的信息,不管数据库是否分片

如果在数据库上执行sh.enableSharding(“db_name”) ,那么字段partitioned字段值就是true;primary 字段指定数据库的主分片(primary shard)。

3,collections集合保存所有已分片集合的信息,不包括非分片集合(un-sharded collections)

key是:分片的片键

4,chunks 集合保存数据块信息,

ns:分片的集合,结构是:db_name.collection_name

min 和 max: 片键的最小值和最大值

shard:块所在的分片

5,changelog集合记录分片集群的操作,包括chunk的拆分和迁移操作,Shard的增加或删除操作

what 字段:表示操作的类型,例如:multi-split表示chunk的拆分,

6,tags 记录shard的tag和对应的片键范围

7,settings 集合记录均衡器状态和chunk的大小,默认的chunk size是MB。

8,locks 集合记录分布锁(distributed lock),保证只有一个mongos 实例能够在分片集群中执行管理任务。

mongos在担任balancer时,会获取一个分布锁,并向config.locks中插入一条doc。

The locks collection stores a distributed lock. This ensures that only one mongos instance can perform administrative tasks on the cluster at once. The mongos acting as balancer takes a lock by inserting a document resembling the following into the locks collection.

三,删除分片

删除分片时,必须确保该分片上的数据被移动到其他分片中,对于以分片的集合,使用均衡器来迁移数据块,对于非分片的集合,必须修改集合的主分片。

深入理解MongoDB分片的管理(深入理解计算机系统)

1,删除已分片的集合数据

step1,保证均衡器是开启的

step2,将已分片的集合全部迁移到其他分片

removeShard命令会将数据块从当前分片上迁移到其他分片上去,如果分片上的数据块比较多,迁移过程可能耗时很长。

step3,检查数据块迁移的状态

使用removeShard命令能够查看数据块迁移的状态,remaining 字段表示剩余数据块的数量

step4,数据块完成迁移

2,删除未分片的数据库

step1,查看未分片的数据库

未分片的数据库,包括两部分:

1、数据库未被分片,该数据没有使用sh.enableSharding(“db_name”) ,在数据库config中,该数据库的partitioned字段是false

2、数据库中存在collection未被分片,即当前的分片是该集合的主分片

对于partitioned=false的数据库,其数据全部保存在当前shard中;对于partitioned=true,primary=”shard_name“的数据库,表示存在未分片(un-sharded collection)存储在该数据库中,必须变更这些集合的主分片。

step2,修改数据库的主分片

四,增加分片

由于分片存储的是数据集的一部分,为了保证数据的高可用性,推荐使用Replica Set作为shard,即使Replica Set中只包含一个成员。连接到mongos,使用sh辅助函数增加分片。

不推荐将standalone mongod作为shard

五,特大块

在有些情况下,chunk会持续增长,超出chunk size的限制,成为特大块(jumbo chunk),出现特大块的原因是chunk中的所有doc使用同一个片键(shard key),导致MongoDB无法拆分该chunk,如果该chunk持续增长,将会导致chunk的分布不均匀,成为性能瓶颈。

在chunk迁移时,存在限制:每个chunk的大小不能超过2.5万条doc,或者1.3倍于配置值。chunk size默认的配置值是MB,超过限制的chunk会被MongoDB标记为特大块(jumbo chunk),MongoDB不能将特大块迁移到其他shard上。

MongoDB cannot move a chunk if the number of documents in the chunk exceeds either documents or 1.3 times the result of dividing the configured chunk size by the average document size.

1,查看特大块

使用sh.status(),能够发现特大块,特大块的后面存在 jumbo 标志

2,分发特大块

特大块不能拆分,不能通过均衡器自动分发,必须手动分发。

step1,关闭均衡器

step2,增大Chunk Size的配置值

由于MongoDB不允许移动大小超出限制的特大块,因此,必须临时增加chunk size的配置值,再将特大块均衡地分发到分片集群中。

step3,移动特大块

step4,启用均衡器

step5,刷新mongos的配置缓存

强制mongos从config server同步配置信息,并刷新缓存。

六,均衡器

均衡器是由mongos转变的,就是说,mongos不仅负责将查询路由到相应的shard上,还要负责数据块的均衡。一般情况下,MongoDB会自动处理数据均衡,通过config.settings能够查看balancer的状态,或通过sh辅助函数查看

返回true,表示均衡器在正运行,系统自动处理数据均衡,使用sh辅助函数能够关闭balancer

balancer不能立即终止正在运行的块迁移操作,在mongos转变为balancer时,会申请一个balancer lock,查看config.locks 集合,

如果state=2,表示balancer正处于活跃状态,如果state=0,表示balancer已被关闭。

均衡过程实际上是将数据块从一个shard迁移到其他shard,或者先将一个大的chunk拆分小的chunk,再将小块迁移到其他shard上,块的迁移和拆分都会增加系统的IO负载,最好将均衡器的活跃时间限制在系统空闲时进行,可以设置balancer的活跃时间窗口,限制balancer在指定的时间区间内进行数据块的拆分和迁移操作。

均衡器拆分和移动的对象是chunk,均衡器只保证chunk数量在各个shard上是均衡的,至于每个chunk包含的doc数量,并不一定是均衡的。可能存在一些chunk包含的doc数量很多,而有些chunk包含的doc数量很少,甚至不包含任何doc。因此,应该慎重选择分片的索引键,即片键,如果一个字段既能满足绝大多数查询的需求,又能使doc数量均匀分布,那么该字段是片键的最佳选择。

总结

标签: 深入理解计算机系统

本文链接地址:https://www.jiuchutong.com/biancheng/312570.html 转载请保留说明!

上一篇:mongodb中随机获取1条记录的实现方法(mongodb 统计)

下一篇:MongoDB windows解压缩版安装教程详解(mongodb win7)

  • 特别关税是多少人民币
  • 小规模纳税人升级一般纳税人流程
  • 预提所得税的计税基础
  • 增值税和附加税如何计算
  • 车辆购置税计入成本吗
  • 进口商品仓库
  • 外购入库暂估补差单怎么去除
  • 核定征收可以改查账征收吗
  • 净现值为零时的收益率
  • 资本公积金转增股本是利好吗
  • 没有发票如何报账
  • 公司转让会计分录
  • 库存盘盈如何入账
  • 建筑业企业分包出克的是否能上报
  • 发微信验证消息
  • 公司商务卡可以日常消费
  • 工资做账原始凭证是什么
  • 工资薪金总额包括职工福利费吗
  • 残疾人就业保障金
  • 计入成本的有哪些科目
  • 私人账户转到企业账户
  • 工资薪金所得的个人所得税筹划方法
  • 核定应纳税额的具体程序和方法
  • 如何进行公司注销流程
  • 如何能屏蔽自动扣费服务
  • win11专业版企业版家庭版哪个玩游戏好
  • 营业外支出是否需要发票
  • windows 安装
  • 如何修改去年的智慧团建评议结果
  • 全年一次性奖金税收计算器
  • win10预览版是什么意思
  • 电商快递费怎么算
  • 公司卖旧车税务处理流程
  • PHP:pcntl_signal()的用法_PCNTL函数
  • 居民企业境外所得税率
  • 企业财务人员如何防范电信诈骗
  • 张家界天门山介绍简介
  • 解决laravel 5.1报错:No supported encrypter found的办法
  • 全网最详细的李白解说来了
  • AttributeError: cannot assign module before Module.__init__() call
  • php不执行
  • 科目汇总表借方发生额等于贷方发生额吗
  • python的pillow库如何安装
  • 在建工程怎么填
  • 应交税费中应交企业所得税为负数怎么调报表
  • 计提坏账准备不会影响应收账款账面价值
  • 行政事业单位福利费列支范围及标准2023
  • 资产负债表投资性房地产怎么填
  • python PyQt如何使用资源
  • 织梦图片要放哪里
  • 现汇跟承兑有什么区别
  • 软件退税款会计如何处理
  • 固定资产原价怎么计算
  • 领用自产应税消费品用于财务人员职工福利
  • 水利建设行业
  • 员工社保,个税怎么计算
  • 贸易融资具体包括
  • sql以级联的方式删除表
  • jdbc连接sqlserver数据库查询数据画饼图
  • sqlserver的主数据库是什么
  • mysql57安装过程怎样选安装目录
  • windows2000自动登陆
  • win8显示桌面图标
  • win10周年版
  • hptasks.exe是病毒吗 是什么进程 hptasks进程说明
  • xp输入法图标不显示图片
  • win7系统注册表损坏无法启动
  • win10系统故障恢复
  • win7系统待机设置
  • win10升级win1
  • cocos creator 碰撞检测
  • node copyfile
  • 基于nodejs的项目
  • 什么是批处理模式
  • 批处理应用实例
  • android查询数据库
  • a+bpython
  • python迭代器iterator
  • 审计的起源和发展史
  • 消费税记不记入成本
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设