MongoDB部署策略

news2025/1/19 11:32:42

本文介绍了MongoDB数据库的优点的数据存储模式的安装部署过程。

利用MongoDB在存储海量数据上的优势,部署存储空间大数据。

·欢迎批评指正补充

由于编者水平有限,所搜集资料也很有限,制定的规范肯定有考虑不周全、甚至完全错误的地方,欢迎大家批评指正。这些内容肯定很不全面,有什么好的原则、经验,也欢迎补充。

  • 安装MongoDB

MongoDB官方已经发布了Win,Linux,MAC ,Solaris 4种平台的发布包,最新的版本是3.2.3,MongoDB遵循了偶数版本较为稳定的发布策略,这里推荐下载(2.4.x,2.6.x,3.0.x)版本。(安装版本推荐使用64位版本,因为MongoDB自身并不管理内存,这些工作都是交由操作系统完成,所以寻址空间只支持2.8G,同时MongoDB的性能与内存大小有直接关联)下载地址是http://www.mongodb.org/downloads

      1. 解压

下载完成后,解压,就可以直接运行bin目录下的二进制文件,一般意义上的安装MongoDB,就是安装MongoDB的服务端进程mongod,如图1-1所示。

图1-1 解压后的文件

      1. 配置目录环境(win平台为例)

bin目录下的mongod.exe在运行时需要配置数据文件目录,如:D:\mongodb\db_rs0\data\rs0_0;同时指定一个日志接收文件,如: D:\mongodb\db_rs0\logs\1.log;配置服务配置文件的路径,如:D:\mongodb\db_rs0\logs,也可以直接运行下列命令>mongod -- dbpath D:/mongodb\db_rs0\data\rs0_0 ,Linux下的安装可以利用对应的包管理器,系统自动创建目录和日志文件。

      1. 集群配置(复制集)

Mongo复制集的配置:

复制集操作实现了数据库的冗余,用于数据从故障中的恢复,同时以复制集的冗余也保证了分片功能的稳定。

一般来说,一个复制集至少需要3个节点,每个节点都是mongod的一个实例,节点之间通过心跳检测检查对方状态。复制集分为:Primary,Second,Arbiter节点,primary负责读写,second负责备份,(在对数据一致性要求不是很严格的情况下,有时可以让primary只负责写,副节点负责读操作,在MongoDB空闲时完成数据的更新,这样能提高一定的性能)arbiter不参与数据处理,arbiter只在primary节点故障时,起到裁决新primary节点的任务。

具体配置如下:

1:、创建3个节点的数据目录

D:\mongodb\db_rs0\data\rs0_0;

D:\mongodb\db_rs0\data\rs0_1;

D:\mongodb\db_rs0\data\rs0_2;

2、创建3个节点的日志目录

D:\mongodb\db_rs0\logs\rs0_0.log;

D:\mongodb\db_rs0\logs\rs0_1.log;

D:\mongodb\db_rs0\logs\rs0_2.log;

3、创建3个节点的启动配置文件

D:\mongodb\configs_rs0\rs0_0.conf;

D:\mongodb\configs_rs0\rs0_1.conf;

D:\mongodb\configs_rs0\rs0_2.conf;

4、3个节点的配置文件的配置

dbpath=D:\mongodb\db_rs0\data\rs0_0            这里是该节点的数据目录

logpath=D:\mongodb\db_rs0\logs\rs0_0.log   这里是该节点的日志目录

journal=true   是否需要Journal日志功能

port=40000   端口号

replSet=rs0   复制集号

5、编写MongoDB实例启动代码

rs0start.bat:

@D:\mongodb\bin\mongod -config D:\mongodb\configs_rs0\rs0_0.conf

rs1start.bat:

@D:\mongodb\bin\mongod -config D:\mongodb\configs_rs0\rs0_1.conf

rs2start.bat:

@D:\mongodb\bin\mongod -config D:\mongodb\configs_rs0\rs0_1.conf

运行上面3个启动代码,就开启了MongoDB实例服务,第一次使用需要对复制集初始化,以及设置primary,second,arbiter节点。

6、运行mongo客户端:

>mongo --port 40000(服务端口号)

>rs.initiate()       (初始化rs0对象,这里其实是在磁盘上开辟空间,MongoDB会保留一部分磁盘空间,并不删除,提高数据处理响应速度)

(这里返回如果是OK,初始化就完成了)

>rs.conf()         (查看节点信息)

添加其余两个节点作为second与arbiter节点

rs0:primary>rs.add("主机号(IP):端口号")

{“ok”:1}

rs0.primary>rs.addArb("主机名(IP):端口号")

注意:

如果需要修改replica域名信息:

cfg=rs.conf()

cfg.members[复制集号].host="Ip:port"

rs.reconfig(cfg)

      1. 集群配置(分片)

Mongo分片的配置:

分片集群操作实现了数据的海量存储,查询。

分片集群分为3个部分:shard,mongos路由进程,配置服务器,其中shard就是单个mongod实例(一般是一个复制集,每个复制集的节点可以不布置到同一个主机);mongos路由进程对客户端是透明的,在用户看来,整个集群就是一个服务;配置服务器其本质也是一个mongod实例,它存储了分片信息,以提供给上层的mongos路由进程使用,这里存储了所有数据库的分片情况,正是有了这些信息,在分片集群上的查询的速度有了保证。

具体配置如下:

1、复制集的配置如1.3所示,只是需要配置多个复制集

2、配置configure服务器

(为了保证分片集群在故障后的恢复,一般将服务器也设置成复制集的形式)

configure服务配置文件:

dbpath= D:\mongodb\db_configs\data\db_config0            

logpath= D:\mongodb\db_configs\logs\db_config0.log   

journal=true   

port=40006   

configsvr=true 声明这是一个集群的configure服务

3、启动mongos路由服务器:

配置cfg_mongos.conf:

logpath=D:\mongodb\mongos\logs\mongos.log

port=40009

configdb=IP1:PORT1, IP2:PORT2, IP3:PORT3

4启动路由服务器:

>mongos --config D:\mongodb\mongos\cfg_mongos.conf

5、添加复制集至集群中:

>mongo --port 40009

mongos>sh.addShard("复制集名/复制集中不包含arbiter的所有节点")

  • 集合分片
      1. 数据库设置

分片设置完成后,需要对选定的数据库集合分片,首先需要使数据库支持分片

如下:

1、连接到集群中的mongos实例:

>mongo --port 40009

2、创建或打开数据库

mongos>use 数据库名

3、使数据库支持分片

mongos>sh.enableSharding("数据库名")

4、创建基于片键的索引使集合分片

mongos>db.users.ensureIndex({片键:1})

mongos>db.shardCollection(“库名.集合名”,{片键:1})

  • MongoDB安全设置
      1. 角色设置

1、mongod启动后,默认是没有打开权限认证的功能的,需要mongod实例修改配置文件

如下:

dbpath= D:\mongodb\db_rs0\data\rs0_0           

logpath= D:\mongodb\db_rs0\logs\rs0_0.log   

journal=true   

port=40000

auth=true

2、启动mongod命令

rs0start.bat:

@D:\mongodb\bin\mongod -config D:\mongodb\configs_rs0\rs0_0.conf

3、创建角色:


>db.createUser(

{

user:"角色名",

pwd:"密码",

roles:[{role:"系统角色",db:"admin(admin是用于管理角色的数据库,保存权限信息)"}

]

}

4、下次登陆就需要:

>mongo --port 端口号 -u 角色名 -p密码 --authenticationDatabase admin

注意:

1、系统角色:readAnyDatabase(只读)

   readwriteAnyDatabase(读写)

   userAdminAnyDatabase(用户管理)

   dbAdminAnyDatabase(管理)

root(包括上面4个)

2、复制集,分片权限:

每个节点启动的指令

>mongo --keyFile 存储密码的txt文件路径

其余设置与单个实例设置相同

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1449789.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用路由懒加载和CDN分发策略对极客园项目进行性能优化

文章目录 前言1.配置路由懒加载2.项目资源打包3.包体积可视化分析4.cdn配置 总结 前言 极客园项目的完成之后,我们需要对项目进行打包以及性能优化,优化用户体验以及加快响应时间,本文只列举了路由懒加载和cdn分发的策略 1.配置路由懒加载 …

Spring Security学习(四)——登陆认证(包括自定义登录页)

前言 和前面的文章隔了很长时间才更新Spring Security系列,主要原因一个是之前太忙了,把项目都忙完了,赶上春节假期,就慢慢研究。Spring Security的体系非常复杂,一口吃不了热豆腐,没办法速成,…

​StableSwarmUI#超越文本的prompt

今天看到一个新的webui方案,是Stability-AI开源的: StableSwarmUI 是一个模块化的稳定扩散web用户界面,着重于使强大的工具易于访问、高性能和可扩展性。 由于项目还在开发中,我们可以先了解下,翻看了它的特点&#xf…

年假作业11

一、选择题 ADDAADADC&#xff0c;BD,D,B,BD,D,C,CD 二、填空题 6 2&#xff0c;3,5,7,9 rgb *s, - a 2,5 *s 三、编程题 1、 #include <iostream> using namespace std; int main() {int arr[10]{10,20,30,40,50,60,70,80,90,100};int m;//从标准输入读取一个…

[职场] 应聘销售的简历怎么写 #职场发展#笔记

应聘销售的简历怎么写 应聘销售的简历怎么写1 基本信息 姓名&#xff1a;吴x 性别&#xff1a;女 毕业院校&#xff1a;徐州师范大学计算机科学院 学历&#xff1a;大专 联系电话&#xff1a;电子邮件&#xff1a; 工作经验&#xff1a;4年 求职意向 期望从事职业&#xff1a;销…

【Spring MVC篇】返回响应

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Spring MVC】 本专栏旨在分享学习Spring MVC的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 一、返回静态页面…

嵌入式培训机构四个月实训课程笔记(完整版)-Linux ARM驱动编程第三天-ARM Linux ADC和触摸屏开发 (物联技术666)

链接&#xff1a;https://pan.baidu.com/s/1V0E9IHSoLbpiWJsncmFgdA?pwd1688 提取码&#xff1a;1688 教学内容&#xff1a; 1、ADC S3C2440的A/D转换器包含一个8通道的模拟输入转换器&#xff0c;可以将模拟输入信号转换成10位数字编码。 在A/D转换时钟频率为2.5MHz时&…

ClickHouse--10--临时表、视图

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.临时表1.1 特征1.2 创建一个临时表 2.视图2.1 普通视图2.2 物化视图 1.临时表 1.1 特征 ClickHouse 支持临时表&#xff0c;临时表具备以下特征&#xff1a; 当…

7 大 Android 数据恢复软件,可轻松找回丢失的数据

每年&#xff0c;由于各种原因&#xff0c;数百万人从他们的 Android 设备中丢失数据。它可能像意外删除文件一样简单&#xff0c;也可能像系统崩溃一样复杂。在这种情况下&#xff0c;拥有高效的数据恢复工具可以证明是救命稻草。Mac 用户尤其需要找到与其系统兼容的软件。好消…

D. Divisible Pairs

思路&#xff1a;我们预处理出每个数分别摸上xy的值&#xff0c;用map存一下&#xff0c;然后遍历每个数&#xff0c;如果a b是x的倍数的话&#xff0c;那么他们模x的值相加为x&#xff0c;如果a - b是y的倍数的话&#xff0c;那么他们的模y的值相等。 代码&#xff1a; voi…

Python dict函数

Python中的字典&#xff08;dict&#xff09;是一种非常重要且灵活的数据结构&#xff0c;它提供了键值对的存储和访问机制。字典函数&#xff08;dict()&#xff09;作为创建字典的工具之一&#xff0c;可以从多种数据结构中创建字典对象。在本文中&#xff0c;将深入探讨dict…

[OPEN SQL] 删除数据

DELETE语句用于删除数据库表中的数据 本次操作使用的数据库表为SCUSTOM&#xff0c;其字段内容如下所示 航班用户(SCUSTOM) 需要删除以下数据 1.删除单条数据 语法格式 DELETE <dbtab> FROM <wa>. DELETE <dbtab> FROM TABLE <itab>. DELETE FROM &…

【白话前端】JS库的作用和常见的九种类型—值得收藏

js库就好比预制菜&#xff0c;我们想吃美食没必要从买菜、择菜、炒菜开始&#xff0c;直接加工就行。 一、什么是JS库 JS库&#xff08;JavaScript Library&#xff09;是指一组封装好的函数、方法、类等&#xff0c;用于简化开发者的编程工作。它们通常提供了常用的功能和算…

HCIA-HarmonyOS设备开发认证V2.0-轻量系统内核基础-消息队列queue

目录 一、消息队列基本概念二、消息队列运行机制三、消息队列开发流程四、消息队列使用说明五、消息队列接口六、代码分析&#xff08;待续...&#xff09;坚持就有收获 一、消息队列基本概念 队列又称消息队列&#xff0c;是一种常用于任务间通信的数据结构。队列接收来自任务…

HGAME2024 WEEK2 wp webmisc

web What the cow say? 进入容器有个输入框&#xff0c;尝试ssti、命令执行、代码执行等&#xff0c;最后发现可使用反引号执行命令&#xff1b; 输入 nl app.py 可查看源代码&#xff0c;有功能具体实现、过滤之类的&#xff1b; flag在 /flag_is_here home/flag_c0w54y 中…

【C语言】内存函数memcpy和memmove的功能与模拟实现

1.memcpy 功能&#xff1a;把source指向的前num个字节内容拷贝到destination指向的位置去&#xff0c;可以拷贝任意类型的数据。 注&#xff1a;1.memcpy并不关心\0&#xff0c;毕竟传的也不一定是字符串&#xff0c;因此拷贝过程中遇到\0也不会停下来。 2.num的单位是字节&a…

姿态传感器MPU6050模块的姿态解算

姿态传感器 姿态传感器是基于MEMS技术的高性能三维运动姿态测量系统。它包含三轴陀螺仪、三轴加速度计&#xff0c;三轴电子罗盘等运动传感器&#xff0c;通过内嵌的低功耗ARM处理器得到经过温度补偿的三维姿态与方位等数据&#xff0c;比如角速度&#xff0c;加速度&#xff0…

微信小程序介绍、账号申请、开发者工具目录结构详解及小程序配置

目录 一、微信小程序介绍 1.什么是小程序&#xff1f; 2.小程序可以干什么&#xff1f; 3.微信小程序特点 二、账号申请 1.账号注册 2.测试号申请 三、安装开发工具 四、开发小程序 五、目录结构 JSON 配置 小程序配置 app.json 工具配置 project.config.json 页…

【Java】零基础蓝桥杯算法学习——动态规划例题

例题&#xff1a;2023年第十四届蓝桥杯Java软件开发B组E题 蜗牛 参考解答&#xff1a; 参考代码示例&#xff1a; import java.util.Scanner; public class Main {static int N 100010;static int[] arr new int[N];static int[] a new int[N]; //传送带的起始坐标static …