MongoDB文档--基本安装-linux安装(mongodb环境搭建)-docker安装(挂载数据卷)-以及详细版本对比

阿丹:

        前面了解了mongodb的一些基本概念。本节文章对安装mongodb进行讲解以及汇总。

官网教程如下: 

安装 MongoDB - MongoDB-CN-Manual

 版本特性

下面是各个版本的选择请在安装以及选择版本的时候参考一下:

MongoDB 2.x 版本:

这个版本引入了聚合管道(Aggregation Pipeline)功能,这是MongoDB中一种利用数据管道原理实现数据聚合操作的功能,类似于SQL中的GROUP BY和HAVING子句。此外,2.x版本还增加了分片集群(Sharded Cluster)和可插拔存储引擎(Pluggable Storage Engines)等重要特性。

MongoDB 3.2版本:

这个版本对分片集群(Sharded Cluster)进行了改进,使得配置分片集群更加简单和灵活。此外,3.2版本还增加了部分索引(Partial Indexes)、文档校验(Document Validation)和聚合管道(Aggregation Pipeline)等特性。

MongoDB 3.4版本:

这个版本在数据复制(Replication)和故障恢复(Fault Tolerance)方面进行了改进,使得系统更加可靠和可用。此外,3.4版本还增加了地理空间索引(Geospatial Indexing)、二进制数据(Binary Data)和用户自定义函数(User-Defined Functions)等特性。

MongoDB 4.0版本:

这个版本引入了MongoDB 4.0,这个版本主要聚焦于可扩展性(Scalability)、性能(Performance)和可靠性(Reliability)。它引入了多文档事务(Multi-Document Transactions)、聚合管道(Aggregation Pipeline)和ACID保证(ACID Guarantees)等新特性。

MongoDB 4.2版本:

这个版本在查询和聚合方面有了很大的提升,新增了文本搜索(Text Search)、地理位置查询(Geo-Spacial Query)和固定集合(Fixed View)等特性。同时,4.2版本还增强了聚合管道(Aggregation Pipeline),使其支持更多的操作和操作符。

 简而言之:
不需要事务,建议选择3.4
需要简单事务,建议选择4.0
需要分布式事务或其他必要功能,建议选择4.2
学习用途,建议选择最新版本

根据官方公告,MongoDB 7.0.0-rc10 (release candidate)版本主要引入了以下新特性和改进:

目前最新: 

  1. 引入了新的数据修复工具,可提高数据可用性和一致性。
  2. 改进了副本集的故障恢复,提供了更快的故障转移和数据恢复。
  3. 增强了聚合管道,支持更多的操作和操作符。
  4. 引入了新的地理空间查询和索引功能,可以更轻松地执行地理空间查询。
  5. 改进了性能和可扩展性,提供了更高的吞吐量和更好的持久性保证。

此外,还修复了一些已知的漏洞和错误,提高了系统的稳定性和安全性。总体来说,MongoDB 7.0.0-rc10 引入了许多新特性和改进,有助于提高数据可用性、一致性和性能

本文章分为两个部分:

        普通linux安装-并配置mongodb的环境变量

        docker安装-挂载数据卷到外部

 

普通linux安装

官方网页 (官方下载网址)

Install MongoDB Community Kubernetes Operator | MongoDB

1、在官网下载对应选择版本的tgz包。

 

我这里因为是学习需要所以选择了最新版本。 

 注意打包的格式一定是tgz

2、将文件上传到linux系统中

使用服务器连接工具完成即可。要注意自己的存储路径。

 

 3、解压mongdb安装包

首先进入压缩包所在目录

解压目标文件,linux中解压文件代码如下

cd /压缩包存在路径
tar -zxvf 目标压缩文件.tgz

解压完成后我们就会获得一个mongodb的文件夹。这个时候可以把之前的压缩包删除掉就可以了。

 

该文件夹中包含了bin等文件夹。 

 4、创建mongodb必要的目录

4/1、在/usr/local目录中创建mongodb文件夹

cd /usr/local
mkdir mongodb

注意在哪里创建文件夹要根据自己给mongodb存放在哪里了。

4/2、在mongodb下创建data目录和logs目录,以及日志文件mongodb.log

cd mongodb #进入文件夹
mkdir data
mkdir logs
touch /usr/local/mongodb/logs/mongodb.log

 5、移动mongodb安装目录

将解压后的文件中的所有文件全部移动到咱们自己进行创建的文件夹中去方便管理:

linux语法注意:/*是所有子文件 移动文件使用mv语法

mv mongodb-linux-x86_64-rhel70-7.0.0-rc10/* /usr/local/mongodb

注意:

1、在当前的文件夹下面,也就是说按照文章的路径来说就是需要到/usr/local路径下面

2、后面的路径是要移动到的目标路径

6、设置mongodb的环境变量

如果不做环境配置每次启动的时候就要写很多启动参数。

配置环境变量的启动:

vim /etc/profile

在文件中添加一下配置

export MONGODB_HOME=/usr/local/mongodb
export PATH=$MONGODB_HOME/bin:$PATH

在书写配置文件的时候一定要注意配置文件中的规范,不要出现多余空格,以及需要注意环境变量中的路径。

注意!!!!:

在修改完环境变量以后一定要进行重启或者使用下面代码重新加载修改过的配置文件

source /etc/profile

 使用上述代码将会重新加载 /etc/profile 文件并应用最新的环境变量设置,而无需关闭和重新打开终端。

 或者将终端关闭重新打开也可以重新加载环境

7、添加mongodb配置文件

添加对应配置文件,使用代码编辑配置文件。

vim /etc/mongodb.conf

添加一下常用配置:

#指定数据库路径
dbpath=/usr/local/mongodb/data
#指定MongoDB日志文件
logpath=/usr/local/mongodb/logs/mongodb.log
# 使用追加的方式写日志
logappend=true
#端口号
port=27017 
#方便外网访问,外网所有ip都可以访问,不要写成固定的linux的ip
bind_ip=0.0.0.0
fork=true # 以守护进程的方式运行MongoDB,创建服务器进程
#auth=true #启用用户验证
#bind_ip=0.0.0.0 #绑定服务IP,若绑定127.0.0.1,则只能本机访问,不指定则默认本地所有IP

8、启动和关闭MongoDB

赋予mongoDB文件夹权限

sudo chmod -R 777 /usr/local/mongodb

进入 bin 目录

cd /usr/local/mongodb/bin

启动 MongoDB(-conf 使用配置文件方式启动)

mongod -f /etc/mongodb.conf

关闭 MongoDB(-conf 使用配置文件方式关闭 )

mongod --shutdown -f /etc/mongodb.conf

查看是否运行

#查看进程
ps -ef | grep mongod

 使用可视化工具进行连接测试

注意!!!:

在连接前要确定线上的安全组是否放行端口号,以及在linux上的防火墙端口号是否已经开放。

下面是关闭防火墙的一些指令。

在Linux中,关闭防火墙的指令取决于您使用的具体发行版。大多数发行版都使用了防火墙工具,如iptables或firewalld。

以下是几个常见发行版的关闭防火墙指令:

在Ubuntu或Debian上,可以使用以下命令关闭防火墙:
sudo ufw disable
在CentOS或RHEL上,可以使用以下命令关闭防火墙:
sudo systemctl stop firewalld
或者

sudo iptables -P INPUT ACCEPT
sudo iptables -P output ACCEPT
sudo iptables -P forward ACCEPT
sudo iptables -t nat -P PREROUTING ACCEPT
sudo iptables -t nat -P POSTrouting ACCEPT
sudo iptables -t mangle -P PREROUTING ACCEPT
sudo iptables -t mangle -P POSTrouting ACCEPT
sudo iptables -P INPUT DROP
sudo iptables -P FORWARD DROP
sudo iptables -P OUTPUT DROP
sudo iptables -t nat -P PRERouting DROP
sudo iptables -t nat -P postrouting DROP
sudo iptables -t mangle -P PREROUTING DROP
sudo iptables -t mangle -P POSTrouting DROP
这些命令将关闭iptables防火墙,但是请注意,这些命令可能会对系统造成安全风险

 

 docker安装mongodb并挂载数据卷-版本按照4.2为例

1、拉取mongodb4.2版本镜像

docker pull mongo:4.2

  

2、查看是否有Mongo镜像

docker images

3、创建目录和配置文件

创建目录:

mkdir -p /root/mongo/data
mkdir -p /root/mongo/conf
mkdir -p /root/mongo/log

创建文件:

cd /root/mongo/conf
vim mongodb.conf
#端口
port=27017
#数据库文件存放目录
dbpath=/root/mongo/data
#日志文件存放路径
logpath=/root/mongo/log
#使用追加方式写日志
logappend=true
#以守护线程的方式运行,创建服务器进程
fork=true
#最大同时连接数
maxConns=100
#不启用验证
#noauth=true
#每次写入会记录一条操作日志
journal=true
#存储引擎有mmapv1、wiredTiger、mongorocks
storageEngine=wiredTiger
#访问IP
bind_ip=0.0.0.0
#用户验证
#auth=true

注意上面路径以及连接配置的路径可自定义,根据自己的需求来进行配置已经安排。

4、运行mongo容器(外挂载配置文件和数据)挂载数据卷

docker run -d \
--name mongodb  \
-p 27017:27017 \
-v /root/mongo/data:/data/db \
-v /root/mongo/conf:/data/conf \
-v /root/mongo/log:/data/log \
-e MONGO_INITDB_ROOT_USERNAME=admin \
-e MONGO_INITDB_ROOT_PASSWORD=123456 \
--privileged=true \
--restart always \
mongo:4.2

这段代码是用于在Docker中运行一个名为"mongodb"的容器,并将其映射到本地主机的27017端口。容器的数据、配置和日志目录都被指定到了本地的/root/mongo/data、/data/conf和/data/log目录下。

同时,该容器还设置了两个环境变量:MONGO_INITDB_ROOT_USERNAME和MONGO_INITDB_ROOT_password,分别设置为"admin"和"123456"。这些环境变量可以在容器内部使用,用于MongoDB的初始化数据库设置。

另外,该容器还使用了特权模式(--privileged=true),这可以让容器拥有更多的系统权限。最后,使用了--restart always选项,这意味着容器将始终在退出后自动重启。

综上所述,这段代码的功能是在Docker中运行一个名为"mongodb"的MongoDB容器,并将其映射到本地主机的27017端口,同时将容器的数据、配置和日志目录映射到本地的/root/mongo/data、/data/conf和/data/log目录下,并设置了MongoDB的初始化数据库用户名和密码。容器使用特权模式,并且将始终自动重启。

注意:用户和密码这行并不是必须的。如何不需要这可以将

-e MONGO_INITDB_ROOT_USERNAME=admin \
-e MONGO_INITDB_ROOT_PASSWORD=123456 \

这两行代码删除掉即可。

 

5、检查是否正常运行 

docker ps -a

6、尝试使用可视化工具连接-使用账号密码

使用账号密码连接方式。

 在下面输入用户名和密码。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ELK日志分析系统概述及部署

ELK 平台是一套完整的日志集中处理解决方案,将 ElasticSearch、Logstash 和 Kibana 三个开源工具配合使用,完成更强大的用户对日志的查询、排序、统计需求。 一、ELK概述 1、组件说明 ①ElasticSearch ElasticSearch是基于Lucene(一个全文…

XML约束和解析

文章目录 概述使用场景语法dtd约束Schema约束解析DOM4j(重点) 概述 可扩展的标记性语言 使用场景 以前: 传输数据的媒介。 例如:微服务架构中,可以用xml文件进行多语言之间的的联系。 现在: 做配置文件 现在作为传输数据的媒介…

使用Gunicorn+Nginx部署Flask项目

部署-开发机上的准备工作 确认项目没有bug。用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中,方便部署的时候安装。将项目上传到服务器上的/srv目录下。这里以git为例。使用git比其他上传方式(比如使用pycharm&#xff…

Matlab Optimization Toolbox中的遗传算法工具包(GA)

matlab optimization 中使用了GA求解器 默认的是小于等于 找到GA 工具包 找到 APP选择 Optimization Tool 选择Solver ga - Genetic Algorithm 应用GA solver 定义适应度函数(Fitness function)与问题约束(Constraints) example one 优化函数 sin(x) 2 * cos(x)极其重要的…

浅谈3D隐式表示(SDF,Occupancy field,NeRF)

本篇文章介绍了符号距离函数Signed Distance Funciton(SDF),占用场Occupancy Field,神经辐射场Neural Radiance Field(NeRF)的概念、联系与区别。 显式表示与隐式表示 三维空间的表示形式可以分为显式和隐式。 比较常用的显式表…

高并发与性能优化的神奇之旅

作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得感谢这段苦,让笔者从头到尾去探索,找寻解决之法。 目录 第一站…

让数据管理由繁至简的低代码开发平台

随着社会数字化能力的快速升级,各行各业正逐渐迈向数字化转型的新时代。尤其是AI的爆发,数据智能技术正在彻底改变着这个行业的面貌,随着越来越多的企业开始将人工智能、机器学习和大数据分析技术应用到其业务中,数据的价值正在得…

VirtualBox Ubuntu无法安装增强功能以及无法复制粘贴踩坑记录

在VirtualBox安装增强功能想要和主机双向复制粘贴,中间查了很多资料,终于是弄好了。记录一下过程,可能对后来人也有帮助,我把我参考的几篇主要的博客都贴上来了,如果觉得我哪里讲得不清楚的,可以去对应的博…

Vue.js2+Cesium 四、模型对比

Vue.js2Cesium 四、模型对比 Cesium 版本 1.103.0&#xff0c;低版本 Cesium 不支持 Compare 对比功能。 Demo 同一区域的两套模型&#xff0c;实现对比功能 <template><div style"width: 100%; height: 100%;"><divid"cesium-container"…

论文笔记:Adjusting for Autocorrelated Errors in Neural Networks for Time Series

2021 NIPS 原来的时间序列预测任务是根据预测论文提出用一阶自回归误差预测 一阶差分&#xff0c;类似于ResNet的残差思路&#xff1f;记为pred&#xff0c;最终的预测结果

Java:Map的getOrDefault()方法结果仍为null

1、问题 今天在工作中遇到一个问题&#xff0c;在一个通用的数据处理方法中&#xff0c;方法会从一个Map类型参数通过key里获取对象value&#xff0c;但方法的调用者并不都会传递value实例&#xff0c;若没有获取到value则需要初始化一个&#xff0c;处理方式是调用了Map的getO…

大牛练成记:用JavaScript徒手写出一个日期选择插件

&#x1f3c6;作者简介&#xff0c;黑夜开发者&#xff0c;全栈领域新星创作者✌&#xff0c;阿里云社区专家博主&#xff0c;2023年6月csdn上海赛道top4。 &#x1f3c6;本文已收录于专栏&#xff1a;100个JavaScript的小应用。 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收…

【C语言】初识指针

【C语言】初识指针 一、指针是什么&#xff1f;二、指针和指针类型1. 指针-整数2. 指针的解引用三、野指针1.野指针成因2 .如何规避野指针四、指针运算五、二级指针七、指针数组 &#x1f388;个人主页&#xff1a;库库的里昂&#x1f390;CSDN新晋作者&#x1f389;欢迎 &…

2023年中职组“网络安全”赛项吉安市竞赛任务书

2023年中职组“网络安全”赛项 吉安市竞赛任务书 一、竞赛时间 总计&#xff1a;360分钟 竞赛阶段 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 A模块 A-1 登录安全加固 180分钟 200分 A-2 本地安全策略配置 A-3 流量完整性保护 A-4 事件监控 A-5 服务加固…

自定义el-slider 滑块的样式

最近用到了element组件中的滑块&#xff0c;翻看了官网和网上一些案例&#xff0c;感觉和我要的样式都不太一样&#xff0c;下面记录一下我用到的两种自定义滑块。 效果图 第一种自定义画过的间断点样式 起始样式 滑动的样式 第二种自定义拖动滑块的样式 起始样式 滑动的样…

linux环境安装mysql数据库

一&#xff1a;查看是否自带mariadb数据库 命令&#xff1a;rpm -qa | grep mariadb 如果自带数据库则卸载掉重新安装 命令&#xff1a;yum remove mariadb-connector-c-3.1.11-2.el8_3.x86_64 二&#xff1a;下载mysql 命令&#xff1a;wget -i -c http://dev.mysql.com/…

3D Web轻量化渲染开发工具HOOPS Communicator是什么?

HOOPS Communicator是Tech Soft 3D旗下的主流产品之一&#xff0c;具有强大的、专用的高性能图形内核&#xff0c;是一款专注于基于Web端的高级3D工程应用程序。由HOOPS Server和HOOPS Web Viewer两大部分组成&#xff0c;提供了HOOPS Convertrer、Data Authoring的模型转换和编…

软件安全测试和渗透测试的区别在哪?安全测试报告有什么作用?

软件安全测试和渗透测试在软件开发过程中扮演着不同的角色&#xff0c;同时也有不同的特点和目标。了解这些区别对于软件开发和测试人员来说非常重要。本文将介绍软件安全测试和渗透测试的区别&#xff0c;以及安全测试报告在软件开发和测试过程中的作用。 一、 软件安全测试和…

idea集成jrebel实现热部署

文章目录 idea集成jrebel实现热部署下载jrebel 插件包下载jrebel mybatisplus extensition 插件包基础配置信息情况一其次情况三情况四情况五情况六情况七 验证生效与否 Jrebel热部署不生效的解决办法 idea集成jrebel实现热部署 在平常开发项目中&#xff0c;我们通常是修改完…

XCTF_very_easy_sql

简单的进行sql注入测试后发现不简单尝试一下按照提示 结合这句提示应该是内部访问&#xff0c;所以采用的手段应该是ssrf顺便看看包 唯一值得关注的是set-cookie说回ssrf唯一能使用的方式应该是Gopher协议找到了一个POST的python脚本 import urllib.parsepayload ""…