广告
返回顶部
首页 > 资讯 > 数据库 >MongoDB 3.4中怎么配置sharding分片
  • 940
分享到

MongoDB 3.4中怎么配置sharding分片

2024-04-02 19:04:59 940人浏览 安东尼
摘要

这篇文章给大家介绍mongoDB 3.4中怎么配置sharding分片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 1. 创建配置服务副本集创建

这篇文章给大家介绍mongoDB 3.4中怎么配置sharding分片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1. 创建配置服务副本集
创建数据目录,config目录供配置服务使用,shard目录供分片数据节点使用
[root@Mysql01 ~]# su - monGo
[mongo@mysql01 ~]$ cd /data/db
[mongo@Mysql01 db]$ mkdir config01
[mongo@MySQL01 db]$ mkdir config02
[mongo@MySQL01 db]$ mkdir config03
[mongo@MySQL01 db]$ mkdir shard01
[mongo@MySQL01 db]$ mkdir shard02
[mongo@MySQL01 db]$ mkdir shard03

启动配置服务副本集的每个节点
[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config01 --port 10001


[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config02 --port 10002


[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config03 --port 10003

连接到配置服务器,执行初始化操作
[mongo@MySQL01 ~]$ mongo localhost:10001
MongoDB shell version v3.4.10
connecting to: localhost:10001
MongoDB server version: 3.4.10

> rs.initiate(
...   {
...     _id: "fire",
...     configsvr: true,
...     members: [
...       { _id : 0, host : "MySQL01:10001" },
...       { _id : 1, host : "MySQL01:10002" },
...       { _id : 2, host : "MySQL01:10003" }
...     ]
...   }
... )
{ "ok" : 1 }
fire:SECONDARY> exit
bye

2. 创建分片副本集
启动副本集的每个节点
[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20001 --dbpath /data/db/shard01


[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20002 --dbpath /data/db/shard02


[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20003 --dbpath /data/db/shard03

连接到分片副本集的一个节点,执行副本集初始化操作
[mongo@MySQL01 ~]$ mongo localhost:20001
MongoDB shell version v3.4.10
connecting to: localhost:20001
MongoDB server version: 3.4.10
> rs.initiate(
...   {
...     _id : "flame",
...     members: [
...       { _id : 0, host : "MySQL01:20001" },
...       { _id : 1, host : "MySQL01:20002" },
...       { _id : 2, host : "MySQL01:20003" }
...     ]
...   }
... )
{ "ok" : 1 }
flame:OTHER> exit
bye

3. 通过 mongos 连接到分片集群
[mongo@MySQL01 ~]$ mongos --configdb fire/MySQL01:10001,MySQL01:10002,MySQL01:10003 --port 30000

4. 增加分片到集群
连接到 mongos,增加上面创建的副本集到集群中
[mongo@MySQL01 ~]$ mongo localhost:30000
MongoDB shell version v3.4.10
connecting to: localhost:30000
MongoDB server version: 3.4.10

mongos> sh.addShard( "flame/MySQL01:40001")
{ "shardAdded" : "flame", "ok" : 1 }

开启指定数据库的分片

为sale数据库开启分片功能
mongos> sh.enableSharding("sale")
{ "ok" : 1 }


在sale数据库里面创建一个集合
mongos> use sale
switched to db sale
mongos> 
mongos> show collections
mongos> db.dept.insert({"id":10})
WriteResult({ "nInserted" : 1 })
mongos> db.dept.insert({"id":20})
WriteResult({ "nInserted" : 1 })
mongos> db.dept.insert({"id":30})
WriteResult({ "nInserted" : 1 })

为创建好的集合执行范围分片
mongos> sh.shardCollection("sale.dept", { id : 1 } )
{
"proposedKey" : {
"id" : 1
},
"curIndexes" : [
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "sale.dept"
}
],
"ok" : 0,
"errmsg" : "please create an index that starts with the shard key before sharding."
}

发生报错,需要对集合的分片字段创建索引
mongos> db.dept.ensureIndex({"id" : 1})
{
"raw" : {
"flame/MySQL01:20001,MySQL01:20002,MySQL01:20003" : {
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1,
"$gleStats" : {
"lastOpTime" : {
"ts" : Timestamp(1512224813, 1),
"t" : NumberLong(1)
},
"electionId" : ObjectId("7fffffff0000000000000001")
}
}
},
"ok" : 1
}

对集合执行分片
mongos> sh.shardCollection("sale.dept", { id : 1 } )
{ "collectionsharded" : "sale.dept", "ok" : 1 }

关于MongoDB 3.4中怎么配置sharding分片就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MongoDB 3.4中怎么配置sharding分片

本文链接: https://www.lsjlt.com/news/56439.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MongoDB 3.4中怎么配置sharding分片
    这篇文章给大家介绍MongoDB 3.4中怎么配置sharding分片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 1. 创建配置服务副本集创建...
    99+
    2022-10-18
  • springboot怎么配置sharding-jdbc水平分表
    这篇文章主要讲解了“springboot怎么配置sharding-jdbc水平分表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springboot怎么配置sharding-jdbc水平分表...
    99+
    2023-06-21
  • mongodb分片集群生产环境怎么配置
    要配置MongoDB分片集群的生产环境,您需要执行以下步骤:1. 设计分片策略:确定如何划分数据片段和选择分片键。分片键是用于将数据...
    99+
    2023-08-23
    mongodb
  • mongodb 中怎么设置分片集群
    今天就跟大家聊聊有关mongodb 中怎么设置分片集群,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、先enable sharding,开启数据库...
    99+
    2022-10-18
  • MongoDB中怎么搭建分片集群
    本篇文章为大家展示了MongoDB中怎么搭建分片集群,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MongoDB分片集群基本组件介绍mongos:数据库集群请求的入...
    99+
    2022-10-18
  • MongoDB中怎么实现分片操作
    本篇文章为大家展示了MongoDB中怎么实现分片操作,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.分片简介分片是指将数据拆分,将其分散存在不同机器上的过程.有时...
    99+
    2022-10-18
  • MongoDB中怎么配置副本集
    MongoDB中怎么配置副本集,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。环境准备三台服务器,地址分别是:192.168.248.128192.168.248.13519...
    99+
    2023-06-19
  • mongodb 中怎么利用分片集群创建分片集合
    mongodb 中怎么利用分片集群创建分片集合,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.创建数据库,直接use 即可,没有的话,如果你...
    99+
    2022-10-18
  • MongoDB中怎么实现分片与集群
    这期内容当中小编将会给大家带来有关MongoDB中怎么实现分片与集群,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、 mongodb分片与集群拓扑图二、分片与集群的部署...
    99+
    2022-10-18
  • mongodb中怎么配置主从复制
    本篇文章为大家展示了mongodb中怎么配置主从复制,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mongodb配置主从复制比mysql简单多了1、安装,用配置文件...
    99+
    2022-10-18
  • SpringBoot2 中怎么配置MongoDB数据库
    这期内容当中小编将会给大家带来有关SpringBoot2 中怎么配置MongoDB数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、NoSQL简介1、NoSQL 概念NoSQL( Not Only ...
    99+
    2023-06-02
  • 怎么对mongodb中某个集合做分片
    本篇内容介绍了“怎么对mongodb中某个集合做分片”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本例中t...
    99+
    2022-10-19
  • Mongodb中怎么实现副本集和分片
    这篇文章将为大家详细讲解有关Mongodb中怎么实现副本集和分片,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Python只用mongo事务在python中...
    99+
    2022-10-18
  • 怎么在MongoDB中添加分片副本集
    这篇文章将为大家详细讲解有关怎么在MongoDB中添加分片副本集,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。流程:新建分片副本集使用addShard命令将分片副本集添加到集群中使用addS...
    99+
    2023-06-14
  • MongoDB中怎么修复config配置节点
    这期内容当中小编将会给大家带来有关MongoDB中怎么修复config配置节点,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。修复流程如下:# 登录到config库,查看c...
    99+
    2022-10-18
  • Linux中怎么安装配置MongoDB数据库
    Linux中怎么安装配置MongoDB数据库,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。说明:操作系统:CentOS 5.X 64位IP地址...
    99+
    2022-10-18
  • SAP SD中怎么配置发票分割开票
    这篇文章将为大家详细讲解有关SAP SD中怎么配置发票分割开票,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。SAP SD中如何配置发票分割开票在SAP的开票业务中,用户常常需要根据自己的一些...
    99+
    2023-06-05
  • apllo开源分布式配置中心怎么部署
    今天小编给大家分享一下apllo开源分布式配置中心怎么部署的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。什么是apllo开源...
    99+
    2023-07-05
  • 怎么在Nginx中配置以禁止区分PHP变量名称大小写
    这篇文章主要介绍了怎么在Nginx中配置以禁止区分PHP变量名称大小写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么在Nginx中配置以禁止区分PHP变量名称大小写文章都会有所收获,下面我们一起来看看吧。N...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作