本文介绍在windows环境下如何搭建一个高可用性的mongodb集群。系统环境为win7,mongodb版本为3.6.3。

本文采用的是分片+副本集的方式搭建集群,将分别介绍如何使用副本集和分片来提高可用性。

一、副本集

mongodb的副本集是维护同一个数据集合的多个mongod进程的集合,提供了数据的冗余,提高了可用性,在某些情况下也可以提高读容量。

mongodb官网相关文档:https://docs.mongodb.com/manual/replication/

1.1副本集结构

副本集有三种角色,分别为主节点、副本节点和仲裁节点(可选)。

主节点具有完全的读写操作,并且只有主节点可以进行写操作。

副本节点同步主节点的oplog,保持数据一致。

仲裁节点不保存数据副本,只在选举主节点的投票中有投票权。

1.2部署副本集

这里介绍如何在测试或开发环境中部署副本集。

如果需要限制ip访问,可以使用bind_ip或在mongod.cfg文件中配置。

mongod --bind_ip localhost,198.51.100.1

1.2.1创建必要文件夹

首先创建必要的文件夹,比如db文件夹,log文件夹。这里可以通过命令创建,也可以直接通过文件管理来创建。

1.2.2启动mongod实例

分别对应的副本集节点启动mongod实例,例如:

mongod --replSet rs0 --port 27017 --dbpath /data/db --logpath /data/log/mongod.log --smallfiles --oplogSize 128

replSet指定了副本集的名字,port指定了实例运行的端口,dbpath指定了数据库存储位置,logpath指定了日志存储位置。

smallfiles和oplogSize的设定可以防止在测试或开发环境中占用太多资源。

1.2.3初始化副本集

通过mongo shell或者驱动程序连接到某一个mongod实例。

运行初始化副本集命令:

var rsconf = {
_id: "rs0",
members: [
{
_id: 0,
host: "<hostname>:27017"
},
{
_id: 1,
host: "<hostname>:27018"
},
{
_id: 2,
host: "<hostname>:27019"
}
]
} rs.initiate(rsconf)

可以通过rs.conf(),rs.status()查看副本集状态。

二、分片

分片将数据进行水平分割,提供了一种处理大数据量数据集合和高吞吐量的方式。

2.1分片群集结构

分片群集由三部分构成:

1.shard,存储了分片数据,可部署成一个副本集。

2.mongos,路由器,连接客户端和分片群集,使分片操作对客户端透明。可部署成一个副本集。

3.config server,配置服务器,存储元数据和配置数据。3.4以后必须部署成副本集。

2.2部署分片

2.2.1部署配置服务器副本集

和配置普通副本集唯一不同的是,部署配置服务器副本集需要指定角色为configsvr。

mongod --configsvr --port 27017 --replSet myconfig --dbpath /data/config --logpath /data/log/mongod.log --smallfiles --oplogSize 128

2.2.2部署分片服务器副本集

和配置普通副本集唯一不同的是,部署配置服务器副本集需要指定角色为shardsvr。

mongod --shardsvr --port 28017 --replSet myshard  --dbpath \data\db --logpath \data\log\mongod.log --smallfiles --oplogSize 128

2.2.3部署路由副本集

和配置普通副本集不同的是启动的为mongos实例。

mongos --configdb myconfig/localhost:27017,localhost:27018,localhost:27019 --port 30000 --replSet mymongos --logpath /data/log/mongod.log

2.2.4添加分片

首先通过mongo shell或者驱动连接到mongos实例。

可以修改chunk大小:

use config
db.settings.save( { _id:"chunksize", value: 1 } )

将分片添加到mongos:

sh.addShard( "myshard/localhost:28017,localhost:28018")

2.2.5设置分片

设置数据库分片:

sh.enableSharding("test")

设置集合分片:

分类分片,根据分片键的值范围进行分片:

sh.shardCollection("test.users", { "username" : 1 } )

哈希分片,根据分片键的哈希值进行分片:

sh.shardCollection("test.users", { "username" : "hashed" } )

三、测试

操作mongos插入数据,查看自动分区结果。

var list = ["a","b","c","d","e","f","g","h","i","j","k","l","m","n",
"o","p","q","r","s","t","u","v","w","x","y","z"];
for (var i = 0; i < 100000; i++){
var index = i % 26;
var user = {"username": list[index], "saysomething": "hello"};
db.getCollection("users").insert(user);
}

分片结果:

随着数据插入量的增多,达到块所能存储的最大值后,会形成更多的块:

在数据较少时,各分片之间的数据量差距可能较大。这种差距随着数据量的增大会逐渐缩小,趋近于平衡。

windows下mongodb集群搭建的更多相关文章

  1. windows下Nacos集群搭建与nginx集成

    前言: nacos集群至少需要三个(一般为奇数个)nacos实 例,其前面顶nginx,外界入口从nginx入 一.windows下Nacos集群搭建 将Nacos的解压包复制分成3份,分别是: na ...

  2. Windows下Redis集群搭建

    1.第一步先安装Redis 参照<Windows下Redis安装及使用.docx> 在Redis目录E:/Redis下新建Logs文件夹,并且创建3个端口下的配置文件,记得修改里面的接口 ...

  3. linux下Mongodb集群搭建:分片+副本集

    三台服务器 192.168.1.40/41/42 安装包 mongodb-linux-x86_64-amazon2-4.0.1.tgz 服务规划  服务器40  服务器41  服务器42  mongo ...

  4. MongoDB集群搭建-副本集

    MongoDB集群搭建-副本集 概念性的知识,可以参考本人博客地址: 一.Master-Slave方案: 主从: 二.Replica Set方案: 副本集: 步骤:(只要按步骤操作,100%成功) 1 ...

  5. Linux环境下Hadoop集群搭建

    Linux环境下Hadoop集群搭建 前言: 最近来到了武汉大学,在这里开始了我的研究生生涯.昨天通过学长们的耐心培训,了解了Hadoop,Hdfs,Hive,Hbase,MangoDB等等相关的知识 ...

  6. Mongodb集群搭建之 Replica Set

    Mongodb集群搭建之 Replica Set Replica Set 中文翻译叫做副本集,不过我并不喜欢把英文翻译成中文,总是感觉怪怪的.其实简单来说就是集群当中包含了多份数据,保证主节点挂掉了, ...

  7. mongodb集群搭建过程记录

    mongodb集群搭建花费比较长的时间,在此记录下过程,方便以后使用 一 软件环境 系统:ubuntu 18.04,mongodb 社区版4.2 https://docs.mongodb.com/ma ...

  8. Mongodb 集群搭建以及常见错误

    Mongodb 集群搭建以及常见错误 1 关于Replica Sets +Sharding(主从复制加分片)搭建,不这详细去说,网上有很多,大部分的例子就三台服务器之间做主从复制,分2个shard,架 ...

  9. 最新Windows下Redis集群

    实现简单的Windows下Redis集群配置,以下是配置过程中出现的几个问题: [1]逐个启动7001 7002 7003 7004 7005 7006节点时,出现createing server T ...

随机推荐

  1. windows下安装ubuntu

    在学习linux的过程中,ubuntu无疑是初学者的最佳选择. 下面来列举给Windows系统安装ubuntu双系统的三种方法. 一.虚拟机安装(不推荐) 使用工具:Vmware 如果不是因为迫不得已 ...

  2. 让你的照片更鲜艳------hsv拉伸

    如果你的照片看上去灰蒙蒙的,缺少生机,那么hsv拉伸也许可以帮你的忙.hsv拉伸是一种可以提高图像鲜艳程度的图像增强方法,它能够让图像的颜色更加鲜活.艳丽,而且它的处理结果看上去很自然,比如源图中较暗 ...

  3. 实验4 IIC通讯与EEPROM接口

    1.       用C语言编程,利用定时器产生一个0~99秒变化的秒表,并且显示在数码管上,每过一秒将这个变化写入实验板上AT24C02,当关闭实验板电源,并再次打开实验板电源时,单片机从AT24C0 ...

  4. 数独 php

      数独求解程序 php版 转载请注明出处:http://xiezhenye.com/2008/06/%e6%95%b0%e7%8b%ac%e6%b1%82%e8%a7%a3%e7%a8%8b%e5% ...

  5. selenium在操作隐藏元素时会报错,怎么判断元素是隐藏的?

    首先页面元素隐藏有五种方法: 1. opacity: 0; opacity 属性的意思是设置一个元素的透明度.它不是为改变元素的边界框(bounding box)而设计的.这意味着将 opacity ...

  6. Git项目下载部分文件或文件夹

    我们常常要在Github下载一些源码.示例等,但有时候项目库会比较大,而我关心的只是其中很少的一部分内容,由于众所周知的原因,我们下载git库是比较慢的,过大的项目经常会下载失败,所以只下载部分内容就 ...

  7. WPF 网易云音乐PC端

    简介 (1)左侧菜单采用 Expander+RadioButton: MVVM 绑定 后台的一个Menu 属性(使用转换器) (2)右侧采用Frame绑定Page的方式 ## [更新日志] ### 1 ...

  8. C# 动态创建数据库三(MySQL)

    前面有说明使用EF动态新建数据库与表,数据库使用的是SQL SERVER2008的,在使用MYSQL的时候还是有所不同 一.添加 EntityFramework.dll ,System.Data.En ...

  9. .net mvc 站点自带简易SSL加密传输

    因项目需要,传输数据需要加密,因此有了一些经验,现简易抽出来分享! 请求:前端cryptojs用rsa/aes 或 rsa/des加密,后端.net 解密返回后端.net用rsa/aes 或 rsa/ ...

  10. redis学习笔记-redis的安装

    Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases Redis 支持 32 位和 64 位.这个需要根据你系统平台的实际情况选择, ...