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