热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

图解MongoDB原理(二)

根据上篇文章《图解MongoDB原理》的基本介绍,本文以具体的操作为例继续深入解析mongodb。演示的所有服务都是在一台机器上,我的目录是F:JAVAMongoDBcluster,文件结构如下:说明:1个配置服务结点,1个路由服务结点,三个分片结点。vcD4KPHA+PHN0cm9u

根据上篇文章《图解MongoDB原理》的基本介绍,本文以具体的操作为例继续深入解析mongodb。 演示的所有服务都是在一台机器上,我的目录是F:\JAVA\MongoDB\cluster,文件结构如下: 说明:1个配置服务结点,1个路由服务结点,三个分片结点。 vcD4KPHA+PHN0cm9u

根据上篇文章《图解MongoDB原理》的基本介绍,本文以具体的操作为例继续深入解析mongodb。

演示的所有服务都是在一台机器上,我的目录是F:\JAVA\MongoDB\cluster,文件结构如下:

\

说明:1个配置服务结点,1个路由服务结点,三个分片结点。
<喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+PHN0cm9uZz7G9LavwfezzDwvc3Ryb25nPjwvcD4KPHA+MaGixvS2r2NvbmZpZ7f+zvE8L3A+CjxwPkY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXG1vbmdvXG1vbmdvZCAtY29uZmlnc3ZyIC1kYnBhdGggRjpcSkFWQVxNb25nb0RCXGNsdXN0ZXJcZGF0YVxjb25maWcgLXBvcnQgMjAwMDAgLXJlc3Q8L3A+CjxwPjKhosb0tq9tb25nb3O3/s7xPC9wPgo8cD5GOlxKQVZBXE1vbmdvREJcY2x1c3Rlclxtb25nb1xtb25nb3MgLWNvbmZpZ2RiIDEyNy4wLjAuMToyMDAwMCAtcG9ydCAzMDAwMCAtY2h1bmtTaXplIDU8L3A+CjxwPjOhosb0tq/L+dPQt9bGrLf+zvE8L3A+CjxwPkY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXG1vbmdvXG1vbmdvZCAtc2hhcmRzdnIgLW1hc3RlciAtcG9ydCAyNzAwMSAtZGJwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQxIC1sb2dwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQxXGxvZyAtbG9nYXBwZW5kPGJyPgo8YnI+CkY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXG1vbmdvXG1vbmdvZCAtc2hhcmRzdnIgLW1hc3RlciAtcG9ydCAyNzAwMiAtZGJwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQyIC1sb2dwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQyXGxvZyAtbG9nYXBwZW5kPGJyPgo8YnI+CkY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXG1vbmdvXG1vbmdvZCAtc2hhcmRzdnIgLW1hc3RlciAtcG9ydCAyNzAwMyAtZGJwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQzIC1sb2dwYXRoIEY6XEpBVkFcTW9uZ29EQlxjbHVzdGVyXGRhdGFcc2hhcmQzXGxvZyAtbG9nYXBwZW5kPC9wPgo8cD40oaLBrL3TbW9uZ29zt/7O8TwvcD4KPHA+RjpcSkFWQVxNb25nb0RCXGNsdXN0ZXJcbW9uZ29zJmd0O21vbmdvLmV4ZSAxMjcuMC4wLjE6MzAwMDA8YnI+Ck1vbmdvREIgc2hlbGwgdmVyc2lvbjogMi40Ljg8YnI+CmNvbm5lY3RpbmcgdG86IDEyNy4wLjAuMTozMDAwMC90ZXN0PC9wPgo8cD41oaLH0Lu7zqphZG1pbtPDu6c8L3A+CjxwPm1vbmdvcyZndDsgdXNlIGFkbWluPGJyPgpzd2l0Y2hlZCB0byBkYiBhZG1pbjwvcD4KPHA+NqGiyejWw7fWxqyjujwvcD4KPHA+bW9uZ29zJmd0OyBkYi5ydW5Db21tYW5kKHthZGRzaGFyZDomcXVvdDsxMjcuMC4wLjE6MjcwMDEmcXVvdDt9KTxicj4KeyAmcXVvdDtzaGFyZEFkZGVkJnF1b3Q7IDogJnF1b3Q7c2hhcmQwMDAwJnF1b3Q7LCAmcXVvdDtvayZxdW90OyA6IDEgfTxicj4KbW9uZ29zJmd0OyBkYi5ydW5Db21tYW5kKHthZGRzaGFyZDomcXVvdDsxMjcuMC4wLjE6MjcwMDImcXVvdDt9KTxicj4KeyAmcXVvdDtzaGFyZEFkZGVkJnF1b3Q7IDogJnF1b3Q7c2hhcmQwMDAxJnF1b3Q7LCAmcXVvdDtvayZxdW90OyA6IDEgfTxicj4KbW9uZ29zJmd0OyBkYi5ydW5Db21tYW5kKHthZGRzaGFyZDomcXVvdDsxMjcuMC4wLjE6MjcwMDMmcXVvdDt9KTxicj4KeyAmcXVvdDtzaGFyZEFkZGVkJnF1b3Q7IDogJnF1b3Q7c2hhcmQwMDAyJnF1b3Q7LCAmcXVvdDtvayZxdW90OyA6IDEgfTwvcD4KPHA+N6GitLS9qNPDu6fD+7rNw9zC66O6PC9wPgo8cD5tb25nb3MmZ3Q7IGRiLmFkZFVzZXIoJnF1b3Q7dmluY2UmcXVvdDssJnF1b3Q7dmluY2UmcXVvdDspPGJyPgp7PGJyPgogICAgICAgICZxdW90O3VzZXImcXVvdDsgOiAmcXVvdDt2aW5jZSZxdW90Oyw8YnI+CiAgICAgICAgJnF1b3Q7cmVhZE9ubHkmcXVvdDsgOiBmYWxzZSw8YnI+CiAgICAgICAgJnF1b3Q7cHdkJnF1b3Q7IDogJnF1b3Q7NTA3YWNiOTU4ZTZhNjM1NTg2NDE3NDNkYWRiNDAxNGUmcXVvdDssPGJyPgogICAgICAgICZxdW90O19pZCZxdW90OyA6IE9iamVjdElkKCZxdW90OzU0OGJlMGI3N2JlZTRhZmU5Y2ExNDUzYiZxdW90Oyk8YnI+Cn08L3A+CjxwPjihorbUyv2+3b/ius2x7cno1sO31saso7o8L3A+CjxwPm1vbmdvcyZndDsgZGIucnVuQ29tbWFuZCh7ZW5hYmxlc2hhcmRpbmc6JnF1b3Q7bWVzc2FnZSZxdW90O30pPGJyPgp7ICZxdW90O29rJnF1b3Q7IDogMSB9PGJyPgptb25nb3MmZ3Q7IGRiLnJ1bkNvbW1hbmQoe3NoYXJkY29sbGVjdGlvbjomcXVvdDttZXNzYWdlLmhpc3RvcnkmcXVvdDssa2V5OntfaWQ6MX19KTxicj4KeyAmcXVvdDtjb2xsZWN0aW9uc2hhcmRlZCZxdW90OyA6ICZxdW90O21lc3NhZ2UuaGlzdG9yeSZxdW90OywgJnF1b3Q7b2smcXVvdDsgOiAxIH08L3A+CjxwPjmhorLp0a/L+dPQt9bGrKO6PC9wPgo8cD5tb25nb3MmZ3Q7IGRiLnJ1bkNvbW1hbmQoe2xpc3RzaGFyZHM6MX0pPGJyPgp7PGJyPgogICAgICAgICZxdW90O3NoYXJkcyZxdW90OyA6IFs8YnI+CiAgICAgICAgICAgICAgICB7PGJyPgogICAgICAgICAgICAgICAgICAgICAgICAmcXVvdDtfaWQmcXVvdDsgOiAmcXVvdDtzaGFyZDAwMDAmcXVvdDssPGJyPgogICAgICAgICAgICAgICAgICAgICAgICAmcXVvdDtob3N0JnF1b3Q7IDogJnF1b3Q7MTI3LjAuMC4xOjI3MDMxJnF1b3Q7PGJyPgogICAgICAgICAgICAgICAgfSw8YnI+CiAgICAgICAgICAgICAgICB7PGJyPgogICAgICAgICAgICAgICAgICAgICAgICAmcXVvdDtfaWQmcXVvdDsgOiAmcXVvdDtzaGFyZDAwMDEmcXVvdDssPGJyPgogICAgICAgICAgICAgICAgICAgICAgICAmcXVvdDtob3N0JnF1b3Q7IDogJnF1b3Q7MTI3LjAuMC4xOjI3MDMyJnF1b3Q7PGJyPgogICAgICAgICAgICAgICAgfTxicj4KICAgICAgICBdLDxicj4KICAgICAgICAmcXVvdDtvayZxdW90OyA6IDE8YnI+Cn08YnI+CjwvcD4KPHA+PHN0cm9uZz6zo7z7tO3O8zwvc3Ryb25nPjwvcD4KPHA+w7vT0Mno1sO31sasyrG0tL2o08O7p7GotO2jujwvcD4KPHA+bW9uZ29zJmd0OyBkYi5hZGRVc2VyKCZxdW90O3ZpbmNlJnF1b3Q7LCZxdW90O3ZpbmNlJnF1b3Q7KTxicj4KU2F0IERlYyAxMyAxNDozODo1Ni4xMTYgZXJyb3I6IHs8YnI+CiAgICAgICAgJnF1b3Q7JGVyciZxdW90OyA6ICZxdW90O2Vycm9yIGNyZWF0aW5nIGluaXRpYWwgZGF0YWJhc2UgY29uZmlnIGluZm9ybWF0aW9uIDo6IGNhdXNlZCBiPGJyPgp5IDo6IGNhbg=="t find a shard to put new db on",
"code" : 10185
} at src/mongo/shell/query.js:128

删除分片时上个任务未完成时报错:

mongos> db.runCommand({removeshard:"127.0.0.1:27032"})
{ "ok" : 0, "errmsg" : "Can't have more than one draining shard at a time" }

MongoVUE连接测试

连接界面如下:

\

查看分片:

\

每个chunk 的大小(size)(单位为MB):

\

单个分片存储数据效果:

\

增加分片shard2和shard3后的Balancer操作过程:

\

分片后的数据:

\

查看所有的数据库,其中partitioned为True表示这个数据库设置了分片。

\

config数据库的结构:

\

查看服务状态,可以看到MongoDB支持的最大连接数为20000:

\

mongod启动参数

当启动参数报错时会有提示,还有参数的英文解释:

General options:
-h [ --help ] show this usage information
--version show version information
-f [ --config ] arg configuration file specifying additional options
-v [ --verbose ] be more verbose (include multiple times for more
verbosity e.g. -vvvvv)
--quiet quieter output
--port arg specify port number - 27017 by default
--bind_ip arg comma separated list of ip addresses to listen on
- all local ips by default
--maxConns arg max number of simultaneous connections - 20000 by
default
--logpath arg log file to send write to instead of stdout - has
to be a file, not directory
--logappend append to logpath instead of over-writing
--pidfilepath arg full path to pidfile (if not set, no pidfile is
created)
--keyFile arg private key for cluster authentication
--setParameter arg Set a configurable parameter
--auth run with security
--cpu periodically show cpu and iowait utilization
--dbpath arg directory for datafiles - defaults to \data\db\
--diaglog arg 0=off 1=W 2=R 3=both 7=W&#43;some reads
--directoryperdb each database will be stored in a separate
directory
--ipv6 enable IPv6 support (disabled by default)
--journal enable journaling
--journalCommitInterval arg how often to group/batch commit (ms)
--journalOptions arg journal diagnostic options
--jsonp allow JSONP access via http (has security
implications)
--noauth run without security
--nohttpinterface disable http interface
--nojournal disable journaling (journaling is on by default
for 64 bit)
--noprealloc disable data file preallocation - will often hurt
performance
--noscripting disable scripting engine
--notablescan do not allow table scans
--nssize arg (=16) .ns file size (in MB) for new databases
--profile arg 0=off 1=slow, 2=all
--quota limits each database to a certain number of files
(8 default)
--quotaFiles arg number of files allowed per db, requires --quota
--repair run repair on all dbs
--repairpath arg root directory for repair files - defaults to
dbpath
--rest turn on simple rest api
--slowms arg (=100) value of slow for profile and console log
--smallfiles use a smaller default file size
--syncdelay arg (=60) seconds between disk syncs (0=never, but not
recommended)
--sysinfo print some diagnostic system information
--upgrade upgrade db if needed

Windows Service Control Manager options:
--install install Windows service
--remove remove Windows service
--reinstall reinstall Windows service (equivalent to --remove
followed by --install)
--serviceName arg Windows service name
--serviceDisplayName arg Windows service display name
--serviceDescription arg Windows service description
--serviceUser arg account for service execution
--servicePassword arg password used to authenticate serviceUser

Replication options:
--oplogSize arg size to use (in MB) for replication op log. default is
5% of disk space (i.e. large is good)

Master/slave options (old; use replica sets instead):
--master master mode
--slave slave mode
--source arg when slave: specify master as
--only arg when slave: specify a single database to replicate
--slavedelay arg specify delay (in seconds) to be used when applying
master ops to slave
--autoresync automatically resync if slave data is stale

Replica set options:
--replSet arg arg is [/]
--replIndexPrefetch arg specify index prefetching behavior (if secondary)
[none"_id_only|all]

Sharding options:
--configsvr declare this is a config db of a cluster; default port
27019; default dir /data/configdb
--shardsvr declare this is a shard db of a cluster; default port
27018

mongos启动参数

General options:
-h [ --help ] show this usage information
--version show version information
-f [ --config ] arg configuration file specifying additional options
-v [ --verbose ] be more verbose (include multiple times for more
verbosity e.g. -vvvvv)
--quiet quieter output
--port arg specify port number - 27017 by default
--bind_ip arg comma separated list of ip addresses to listen on - all
local ips by default
--maxConns arg max number of simultaneous connections - 20000 by
default
--logpath arg log file to send write to instead of stdout - has to be
a file, not directory
--logappend append to logpath instead of over-writing
--pidfilepath arg full path to pidfile (if not set, no pidfile is
created)
--keyFile arg private key for cluster authentication
--setParameter arg Set a configurable parameter
--nohttpinterface disable http interface

Windows Service Control Manager options:
--install install Windows service
--remove remove Windows service
--reinstall reinstall Windows service (equivalent to --remove
followed by --install)
--serviceName arg Windows service name
--serviceDisplayName arg Windows service display name
--serviceDescription arg Windows service description
--serviceUser arg account for service execution
--servicePassword arg password used to authenticate serviceUser

Sharding options:
--configdb arg 1 or 3 comma separated config servers
--localThreshold arg ping time (in ms) for a node to be considered local
(default 15ms)
--test just run unit tests
--upgrade upgrade meta data version
--chunkSize arg maximum amount of data per chunk
--ipv6 enable IPv6 support (disabled by default)
--jsonp allow JSONP access via http (has security implications)
--noscripting disable scripting engine

分片&#43;主从安装命令

主从的部署是不具有故障自动转移功能的,而复本集的部署支持故障转移。

主数据结点:
mongod -shardsvr -master -port 27001 -dbpath F:\JAVA\MongoDB\cluster\shard\data
从数据结点:
mongod -shardsvr -slave -source 127.0.0.1:27001 -port 27002 -dbpath F:\JAVA\MongoDB\cluster\shards\data

分片&#43;复本集安装

复本集安装要对每个分片进行设置,用mongo直接连接分片,执行rs.initiate(cfg)进行设置,设置好后需要分别将每个分片加入config中。相关的函数有:

rs.status() { replSetGetStatus : 1 } checks repl set status
rs.initiate() { replSetInitiate : null } initiates set with default settings
rs.initiate(cfg) { replSetInitiate : cfg } initiates setwith configuration cfg
rs.conf() get the current configuration object from local.system.replset
rs.reconfig(cfg) updates the configuration of a running replica set with cfg (disconnects)
rs.add(hostportstr) add a new member to the set with default attributes (disconnects)
rs.add(membercfgobj) add a new member to the set with extra attributes (disconnects)
rs.addArb(hostportstr) add a new member which is arbiterOnly:true (disconnects)
rs.stepDown([secs]) step down as primary (momentarily) (disconnects)
rs.syncFrom(hostportstr) make a secondary to sync from the givenmember
rs.freeze(secs) make a node ineligible to become primary for the time specified
rs.remove(hostportstr) remove a host from the replica set (disconnects)
rs.slaveOk() shorthand for db.getMongo().setSlaveOk()

启动命令

路由结点:
mongos -configdb 127.0.0.1:20000 -port 30000 -chunkSize 5

配置结点:

mongod -configsvr -dbpath F:\JAVA\MongoDB\cluster\config\data -port 20000 -rest

分片1:
mongod -shardsvr -replSet shard1/127.0.0.1:27051,127.0.0.1:27041 -port 27031 -dbpath F:\JAVA\MongoDB\cluster\repa_shard1\data

分片1复本集b:
mongod -shardsvr -replSet shard1/127.0.0.1:27051 -port 27041 -dbpath F:\JAVA\MongoDB\cluster\repb_shard1\data

分片1复本集c:
mongod -shardsvr -replSet shard1/127.0.0.1:27041 -port 27051 -dbpath F:\JAVA\MongoDB\cluster\repc_shard1\data

分片2:
mongod -shardsvr -replSet shard2/127.0.0.1:27052,127.0.0.1:27042 -port 27032 -dbpath F:\JAVA\MongoDB\cluster\repa_shard2\data

分片2复本集b:
mongod -shardsvr -replSet shard2/127.0.0.1:27052 -port 27042 -dbpath F:\JAVA\MongoDB\cluster\repb_shard2\data

分片2复本集c:
mongod -shardsvr -replSet shard2/127.0.0.1:27042 -port 27052 -dbpath F:\JAVA\MongoDB\cluster\repc_shard2\data

WEB控制台

分片服务与配置服务的mongod加上-rest后会有web控制台,具体的地址在启动输出中会有,如下



推荐阅读
  • Mongoose 5.12.10 发布:MongoDB 异步对象模型工具的新特性与修复
    Mongoose 是一款专为异步环境设计的 MongoDB 对象模型工具,支持 Promise 和回调函数。最新版本 Mongoose 5.12.10 带来了多项修复和改进,包括查询选项中的默认值设置、嵌入式判别器填充、以及 TypeScript 定义文件的优化。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 多键索引(MultiKey Indexes)是在包含数组类型字段上创建的特殊索引,旨在优化对数组元素的查询性能。本文将通过实例介绍如何在MongoDB中创建和使用多键索引。 ... [详细]
  • ODBC介绍:开放式数据库连接详解
    本文详细介绍了ODBC(开放式数据库连接),这是一种允许应用程序访问多种数据库系统的标准API。自1992年由微软与Simba合作推出以来,ODBC已成为跨平台数据访问的重要标准。 ... [详细]
  • 利用GitHub热门资源,成功斩获阿里、京东、腾讯三巨头Offer
    Spring框架作为Java生态系统中的重要组成部分,因其强大的功能和灵活的扩展性,被广泛应用于各种规模的企业级应用开发中。本文将通过一份在GitHub上获得极高评价的Spring全家桶文档,探讨如何掌握Spring框架及其相关技术,助力职业发展。 ... [详细]
  • 本文探讨了在 Spring Boot 应用程序中使用 MongoDB 进行复杂文档查询的方法,特别是如何通过实体类映射来处理包含嵌套对象和列表的数据结构。 ... [详细]
  • 近期参与了一个旨在提高在线平台大规模查询响应速度的项目,预计处理的数据量为2-3亿条,数据库并发量约为每秒1500次,未来可能增至3000次。通过对比Redis和MongoDB,最终选择了MongoDB,因其具备优秀的横向扩展性和GridFS支持下的Map/Reduce功能。 ... [详细]
  • ArchSummit深圳2014将于7月18日拉开帷幕,所有讲师已确认,涵盖9个热门话题,共36场精彩报告。InfoQ中文站提供了详细的讲师和报告列表。 ... [详细]
  • 本文详细介绍了如何构建MongoDB的ReplSet复制集群,包括环境准备、配置文件设置以及初始化复制集群的具体步骤。 ... [详细]
  • 本文介绍了使用Node.js开发超市管理系统的经验分享,重点讨论了项目中使用的技术栈及其实现细节,包括前端Bootstrap和后端Express框架的应用,以及MongoDB数据库的操作。 ... [详细]
  • 本文档详细介绍了如何在MongoDB命令行中执行基本操作,包括数据库的选择与创建、文档的插入与查询、文档的更新与删除等。同时,还涵盖了条件查询、统计、模糊查询等高级功能。 ... [详细]
  • Lepus: 高效的企业级数据库监控解决方案
    访问官方网站:http://www.lepus.cc/。Lepus(天兔)数据库监控系统是由一位资深数据库管理员(现任职于一家知名互联网公司)专为互联网企业设计的专业数据库监控平台。该系统旨在提供全面的数据库性能监控与管理服务,支持多种主流数据库类型。 ... [详细]
  • 开发笔记:Mongodb副本集集群搭建 ... [详细]
  • 使用 Docker 部署 MongoDB 并通过 IntelliJ IDEA 远程访问
    本文详细介绍了如何使用 Docker 部署 MongoDB,并通过 IntelliJ IDEA 实现远程连接的方法。包括 MongoDB 的基本配置、用户管理以及如何在 IDE 中配置连接。 ... [详细]
  • 本文深入探讨了分布式文件系统的核心概念及其在现代数据存储解决方案中的应用,特别是针对大规模数据处理的需求。文章不仅介绍了多种流行的分布式文件系统和NoSQL数据库,还提供了选择合适系统的指导原则。 ... [详细]
author-avatar
黄思悦-XHNZ_314
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有