1.分片的原理概述

分片就是把数据分成块,再把块存储到不同的服务器上,mongodb的分片是自动分片的,当用户发送读写数据请求的时候,先经过mongos这个路由层,mongos路由层去配置服务器请求分片的信息,再来判断这个请求应该去那一台服务器上读写数据。

2.分片的条件

1):服务器磁盘不够的时候

2):服务器出现写瓶颈的时候

3):想将大量数据放在内存中提高性能

3.分片中的角色,有三种:

1):配置服务器:存放分片信息,分片的数据与片的关系

2):mongos路由:是一个路由进程,把所有对mongodb的数据读写请求根据配置服务器的配置信息分配到不同的分片服务器上去。本身不存储数据与配置信息,但会缓存配置信息,

3):片:指一个分片,这个分片可以是一台服务器,也可以是多台服务器组成的一个集群。对应的多台服务器中只能有一台主服务器

4.分片是以什么来分的

1)以数据库来分,那就是把数据库里的多个集合分到不同的分片上,同一个集合的数据只能在同一分片上

2)以某个集合中的某个键来分,这个键称为片键,根据设置的片键把一个集合的数据分到不同的片上,这个分片键可以是多个键的组合键

5.实际的生产环境

在一个实际的生产环境中会同时存在多个配置服务器,多个mongos路由进程,多个分片,每一个分片会是一个副本集。

因为配置服务器与mongos路由进程占用的资源非常少,所以有些人会通过不同的端口,把他们配置到同一台服务器上,但是不要把多个配置服务器与多个mongos路由进程配置在同一台服务器,最好是一台服务器一个配置服务器,一个路由进程就够,如果是多个在同一台服务器,当这个服务器挂掉了,那你的整个分片的架构可能就跟着挂了,不能提供服务了,下面给出一个参考的架构图。

6.搭建分片服务器架构的流程

1):创建配置服务器的数据与日志目录,并配置和启动配置服务器,主要参数:mongod --configsvr ..............

2):创建mongos的日志目录,因为mongos本身不存储数据,所以不用数据目录。接着配置和启动mongos路由进程,启动的时候是以mongos,来启动的。主要参数:mongos --configdb 配置服务器的ip:端口 ............

3) :  创建分片副本集的数据与日志目录,配置和启动副本集,主要参数:mongod --shardsvr --replSet 副本集名 .........

4):对分片副本集进行初始化,设置仲裁节点,把初始化信息写在config变量中,接着用rs.initiate(config)进行初始化

5):登录mongos,把副本集增加到切片中,必须在admin数据中运行命令:db.runCommand({"addshard":"副本集名称/ip:port,ip:port......","name":"分片名"})

6):打开数据库和集合的分片功能db.runCommand({"enableSharding":"数据库"}),db.runCommand({"shardcollection":"数据库.集合名","key":{"键名":1}})

7.分片架构规划

1)规划:如果按以上的架构图来搭建没有这么多服务器,所以我们以三台服务器为例分别是:192.168.1.1,192.168.1.2,192.168.1.3

配置服务器的端口是:20000,mongos路由的端口是:20004,副本集1的端口是:20001,副本集2的端口是:20002,副本集3的端口是:20003

2):架构图如下:

8.开始搭建分片

创建一个总目录shard,之后创建的目录都在这个文件夹中,假设现在正在mongodb的安装目录下,目录名为mongodb,在根目录下。

1):配置与启动配置服务器

  mkdir ./shard/config //配置服务器的目录

mkdir ./shard/config/data  //配置服务器的数据目录

mkdir ./shard/config/log  //配置服务器的日志目录

//配置和启动配置服务器

mongod --configsvr --dbpath="/mongodb/shard/config/data" --logpath="/mongodb/shard/config/log/config.log" --port 2000 --fork --logappend

把以上的步骤分别在三台服务器中执行一遍

2):配置和启动mongos路由进程

  mkdir ./shard/mongos   //配置服务器的目录

mkdir ./shard/mongos/log  //配置服务器的日志目录

配置和启动mongos

  mongos --configdb 192.168.1.1:20000,192.168.1.2:20000,192.168.1.3:20000 --logpath="/mongodb/shard/mongos/log/mongos.log" --port 2004 --fork --logappend

  把以上的步骤分别在三台服务器中执行一遍

3):创建与启动第一副本集,并加入到分片中

  mkdir ./shard/replset/rs1/data

  mkdir ./shard/replset/rs1/log

echo  -n 'shard'  | md5sum >> ./auth.txt(配置通信凭证文件)

配置和启动副本集

mongod --shardsrv --replset rs1 --keyFile  ./auth.txt  --dbpath=./shard/replset/rs1/data  --logpath=./shard/replset/rs1/log/rs1.log --fork --port 20001 --logappend

分别在三台服务器中执行以上命令

登录其中的一台并配置副本集:mongo 192.168.1.1:2001

var config = {"_id":rs1,member:[{_id:1,host:192.168.1.1:20001},{_id:1,host:192.168.1.2:20001},{_id:1,host:192.168.1.3:20001,'arbiteOnly':true}]}

rs.initiate(config);

登录其中一台mongos路由并把副本集加到分块中:

mongo 192.168.1.1:20004

db.runCommand({"addshard":"rs1/192.168.1.1:20001,192.168.1.2:20001,192.168.1.3:20001"}); //增加副本集到分片中

db.runCommand({"enbaleSharding":test(数据库名)});//启动数据库分片

db.runCommand({"shardCollection":test.user(集合名),key:{name(分块键):1}});//按数据库中的某个集合的某个健分片

4)重复第3个步骤创建rs2,rs3,但要修改相对应的地方,比如端口,和文件夹名称,副本集名称

5.查看分片的状态:db.printShardingStatus();

db.runCommand({"listShards":1});

6.删除分片:

db.runCommand({"removeshard":"ip:端口"});

删除的分片上的数据会移到其他分片上,移完之后自动删除分片.

  

mongodb系列之--分片的原理与配置的更多相关文章

  1. 13.MongoDB系列之分片简介

    1. 分片概念 分片是指跨机器拆分数据的过程,有时也会用术语分区.MongoDB既可以手工分片,也支持自动分片 2. 理解集群组件 分片的目标之一是由多个分片组成的集群对应用程序来说就像是一台服务器. ...

  2. 16.MongoDB系列之分片管理

    1. 查看当前状态 1.1 查看配置信息 mongos> use config // 查看分片 mongos> db.shards.find() { "_id" : & ...

  3. MongoDB分片技术原理和高可用集群配置方案

    一.Sharding分片技术 1.分片概述 当数据量比较大的时候,我们需要把数分片运行在不同的机器中,以降低CPU.内存和Io的压力,Sharding就是数据库分片技术. MongoDB分片技术类似M ...

  4. 14.MongoDB系列之配置分片

    1. 启动服务器 1.1 启动配置服务器 配置服务器是集群的大脑,保存着关于每个服务器包含哪些数据的所有元数据,因此,必须首先创建配置服务器. 由于资源限制,在同一机器上启动三个进程 # mkdir ...

  5. mongodb系列之---副本集配置与说明

    在配置副本集之前,我们先来了解一些关于副本集的知识. 1,副本集的原理 副本集的原理与主从很相似,唯一不同的是,在主节点出现故障的时候,主从配置的从服务器不会自动的变为主服务器,而是要通过手动修改配置 ...

  6. mongodb复制+分片集原理

    ----------------------------------------复制集---------------------------------------- 一.复制集概述: Mongodb ...

  7. MongoDB 分片的原理、搭建、应用 !

    MongoDB 分片的原理.搭建.应用   一.概念: 分片(sharding)是指将数据库拆分,将其分散在不同的机器上的过程.将数据分散到不同的机器上,不需要功能强大的服务器就可以存储更多的数据和处 ...

  8. Mongodb 笔记07 分片、配置分片、选择片键、分片管理

    分片 1. 分片(sharding)是指将数据拆分,将其分散存放在不同的机器上的过程.有时也用分区(partitioning)来表示这个概念.将数据分散到不同的机器上,不需要功能强大的大型计算机就可以 ...

  9. mongodb系列之--mongodb 主从配置与说明

    一.为什么要配置mongodb的主从: 1.做主从,可以说是做数据的备份,有利于故障的恢复 2.做主从,可以做到读写分离,主节点负责写操作,从节点负责读操作,这样就把读写压力分开,保证系统的稳定性. ...

随机推荐

  1. Dynamics CRM 构建IN查询

    CRM中有3种查询数据的方式,分别是QueryExpression.fetchxml.linq,本篇讲述的条件IN的查询只支持前两种,linq并不支持. QueryExpression的写法如下,示例 ...

  2. Android简易实战教程--第三十六话《电话录音》

    今天完成一个简单的电话录音功能,即接通电话后,立即录下自己打电话的声音.实现起来比较简单:一个服务,一个TelephonyManager.一个MediaRecorder就够了. 1.布局提供一个开启录 ...

  3. 在Mac上搭建React Native开发环境

    概述 前面我们介绍过在window环境下开发React Native项目,今天说说怎么在mac上搭建一个RN的开发环境. 配置mac开发环境 基本环境安装 1.先安装Homebrew:用于安装Node ...

  4. android Handler机制之ThreadLocal详解

    概述 我们在谈Handler机制的时候,其实也就是谈Handler.Message.Looper.MessageQueue之间的关系,对于其工作原理我们不做详解(Handler机制详解). Messa ...

  5. Windows 8 Cython 的配置(解决Unable to find vcvarsall.bat问题)

    关键是安装之前配置编译器. 1.下载MinGW 编译器 http://www.mingw.org/download.shtml 2.把编译器路径(例如C:\Program Files (x86)\Co ...

  6. RxJava(七) 使用debounce操作符 优化app搜索功能

    欢迎转载,转载请标明出处: http://blog.csdn.net/johnny901114/article/details/51555203 本文出自:[余志强的博客] 一.抛出问题 现在几乎所有 ...

  7. Gazebo機器人仿真學習探索筆記(三)機器人模型

    gazebo_models:https://bitbucket.org/osrf/gazebo_models 模型庫下載,可以參考如下命令: ~/Rob_Soft/Gazebo7$ hg clone ...

  8. iOS中NSTimer的invalidate调用之后

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交 ...

  9. 自定义控件辅助神器ViewDragHelper

    ViewDragHelper作为官方推出的手势滑动辅助工具,极大的简化了我们对手势滑动的处理逻辑,v4包中的SlidingPaneLayout和DrawerLayout内部都有ViewDragHelp ...

  10. JS和Jquery操作label标签

    获取label值:  label标签在JS和Jquery中使用不能像其他标签一样用value获取它的值: 代码如下: var label=document.getElementById("s ...