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

news2025/1/18 11:45:02

阿丹:

        前面了解了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、尝试使用可视化工具连接-使用账号密码

使用账号密码连接方式。

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

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

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

相关文章

TensorRT学习笔记--基于YoloV8检测图片和视频

1--完整项目 完整项目地址:https://github.com/liujf69/TensorRT-Demo git clone https://github.com/liujf69/TensorRT-Demo.gitcd TRT_YoloV8 2--模型转换 cd yolov8python gen_wts.py 3--编译项目 mkdir buildcd build cmake .. # 需要更改 CMakeLists.txt…

postgresSQL Extended Query执行过程和sharding-proxy的处理

pg Extended Query PostgreSQL: Documentation: 15: 55.2. Message Flow 多个阶段,可复用 Parse → DESCRIBE statement → SYNC Parse 解析, 将 sql 文本字符串,解析成 named preparedStatement 语句(生命周期随session&#x…

数据安全能力框架模型-详细解读(一)

8月30日,奇安信集团正式发布“数据安全能力框架”,以及“数据安全概念运行图”(数据安全ConOps),旨在为数字化转型不断深入的大型政企客户以及业内伙伴,提供基于甲方视角的数据安全全面图景,以及…

GESP2023年6月C++一级客观题

一、单选题(每题 2 分,共 30 分) 以下不属于计算机输出设备的有( )。 A. 麦克风 B. 音箱 C. 打印机 D. 显示器 ChatGPT 是 OpenAI 研发的聊天机器人程序,它能通过理解和学习人类的语言 来进行对话&#xf…

ES6之Promise、Class类与模块化(Modules)

目录 PromiseClass类extendssuper Modules 模块系统export default 和对应importexport 和 import Promise Promise 是 ES6 引入的一种用于处理异步操作的对象。 它解决了传统回调函数(callback)模式中容易出现的回调地狱和代码可读性差的问题。 Promis…

Vue.js2+Cesium 四、WMS 服务加载,控制自图层显隐

Vue.js2Cesium 四、WMS 服务加载&#xff0c;控制自图层显隐 Demo <template><divid"cesium-container"style"width: 100%; height: 100%;"><div class"layer_container"><button id"btn">清除</button&g…

大模型开发(十六):从0到1构建一个高度自动化的AI项目开发流程(中)

全文共1w余字&#xff0c;预计阅读时间约40~60分钟 | 满满干货(附代码)&#xff0c;建议收藏&#xff01; 本文目标&#xff1a;通过LtM提示流程实现自动构建符合要求的函数&#xff0c;并通过实验逐步完整测试code_generate函数功能。 代码下载点这里 一、介绍 此篇文章为…

Redis两种持久化方案RDB持久化和AOF持久化

Redis持久化 Redis有两种持久化方案&#xff1a; RDB持久化AOF持久化 1.1.RDB持久化 RDB全称Redis Database Backup file&#xff08;Redis数据备份文件&#xff09;&#xff0c;也被叫做Redis数据快照。简单来说就是把内存中的所有数据都记录到磁盘中。当Redis实例故障重启…

docker---网络

docker网络 使用–publish或-p标志使端口可用于 Docker 外部的服务。这会在主机中创建一条防火墙规则&#xff0c;将容器端口映射到 Docker 主机上通往外界的端口。 -p 8080:80&#xff1a;将容器中的TCP端口80映射到Docker主机上的端口8080。 -p 192.168.1.100:8080:80&…

说明学习委员之作业管理系统—后端部分

项目背景 学习委员收集作业的过程&#xff0c;繁琐且曲折&#xff0c;作者充分理解并体谅为大家服务的苦逼学习委员&#xff0c;以此为出发点和灵感&#xff0c;设计并开发了此套作业管理系统&#xff0c;希望能帮助各位提高效率&#xff0c;早日摆脱重复机械式的工作&#xf…

Vue3和TypeScript_页面

1 在views下新建myView.view 2 在router文件夹里&#xff0c;配置路径&#xff0c;按需引入组件 3 浏览器通过路径访问页面

pycharm——涟漪散点图

from pyecharts import options as opts from pyecharts.charts import EffectScatterc (EffectScatter().add_xaxis( ["高等数学1&#xff0c;2","C语言程序设计","python程序设计","大数据导论","数据结构","大数据…

旺店通·企业奇门和用友U8接口打通对接实战

旺店通企业奇门和用友U8接口打通对接实战 接通系统&#xff1a;旺店通企业奇门 慧策最先以旺店通ERP切入商家核心管理痛点——订单管理&#xff0c;之后围绕电商经营管理中的核心管理诉求&#xff0c;先后布局流量获取、会员管理、仓库管理等其他重要经营模块。慧策的产品线从旺…

QT学习笔记-QT5.15 + MSVC编译套件时编译日志及运行日志日志乱码解决

QT学习笔记-QT5.15 MSVC编译套件时编译日志及运行日志日志中文乱码解决 0、基础环境1、QtCreator中的基本设置编辑->首选项->文本编辑器 2、问题1&#xff1a;MSVC编译日志乱码问题解决问题描述解决方法 3、问题2&#xff1a;MSVC构建套件编译后程序运行日志乱码问题问题…

多雷达探测论文阅读笔记:雷达学报 2023, 多雷达协同探测技术研究进展:认知跟踪与资源调度算法

多雷达协同探测技术 原始笔记链接:https://mp.weixin.qq.com/s?__biz=Mzg4MjgxMjgyMg==&mid=2247486627&idx=1&sn=f32c31bfea98b85f2105254a4e64d210&chksm=cf51be5af826374c706f3c9dcd5392e0ed2a5fb31ab20924b7dd38e1b1ae32abe9a48afa8174#rd ↑ \uparrow …

Redis—全局命令

Redis—全局命令 &#x1f50e;get / set&#x1f50e;常用全局命令keysexistsdelexpirettlkey 的过期策略type Redis 官网 Redis 中的命令不区分大小写 进入 Redis 客户端 redis-cli -h Redis 服务器的 IP 地址 -p Redis 服务器的端口号省略 -h 表示 Redis 服务器的 IP 地址…

【ASP.NET MVC】数据库访问(5)

一、ORM简介 对象关系映射&#xff08;Object Relational Mapping&#xff0c;简称ORM&#xff09;模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。 以上是官话&#xff0c;个人理解&#xff1a; 1、解决问题&#xff1a;数据库的访问 2、如何解决&a…

Vue路由:Vue Router

Vue Router 介绍 Vue Router 是 Vue.js (opens new window) 官方的路由管理器。 核心深度集成&#xff0c;包含的功能有&#xff1a; 嵌套的路由/视图表 模块化的、基于组件的路由配置 路由参数、查询、通配符基于 Vue.js 过渡系统的视图过渡效果 细粒度的导航控制 Vue Rou…

学习系统编程No.33【生产消费模型】

引言&#xff1a; 北京时间&#xff1a;2023/7/22/14:27&#xff0c;现实和预期往往相差是巨大的&#xff0c;哈哈哈&#xff01;白天睡不醒&#xff0c;晚上睡不着&#xff0c;就像一个夜猫子一样。熬夜耍手机&#xff0c;我真的是专业的&#xff0c;已经连续好久没有正常睡过…

【C++】类和对象 - 中

目录 1. 类的6个默认成员函数2. 构造函数2.1 概念2.2 特性3.3 默认构造函数 3. 析构函数3.1 概念3.2 特性 4. 拷贝构造函数4.2 概念4.3 特性4.3 传参或作返回值 5. 赋值运算符重载5.1 运算符重载5.2 赋值运算符重载5.3 前后置 --重载5.4 自定义类型的输出输出 6. const成员函数…