MongoDB 分片

MongoDB 分片

高数据量(消耗内存)和高吞吐量(消耗CPU)的数据库应用会对单机的性能造成较大压力,为了解决这些问题,一般采用两种方法:水平扩展(将数据集分布在多个服务器上)和垂直扩展(增加更多的CPU和存储资源)。

当MongoDB存储海量数据时,一台机器可能不足以存储数据,也可能不足以提供可接受的读写吞吐量。这时,我们可以通过分割数据,使得数据分布在多个服务器上。

1. 分片集群架构
  • Config Server:存储集群所有节点、分片数据数据信息等元数据信息,默认需要配置3个Config Server节点;
  • Mongos:专用路由进程,提供对外应用访问,将客户端发来的请求准确无误的路由到集群中的一个或一组服务器上,同时会把接收到的响应拼装起来发回客户端;
  • Shard:存储数据,以chunk为单位存储数据;
    在这里插入图片描述
1.1 Chunk

在Shard内部,MongoDB还会把数据分为chunks,每个chunk包含shard的一部分数据,chunk的产生有两个用途:

  • Splitting:当chunk的大小超过配置的chunk size(默认为64M)时,MongoD
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值