MongoDB 快速入门+单机部署(附带脚本)

目录

介绍

体系结构

数据模型

BSON

BSON 数据类型

特点

高性能

高可用

高扩展

丰富的查询支持

其他特点

部署

单机部署

普通安装

脚本安装

Docker Compose 安装

卸载

停止 MongoDB

删除包

删除数据目录


参考: https://docs.mongoing.com/

介绍

Mongodb 是一个开源的,高性能,五模式的文档行数据库,当初的设计就是用于简化开发和方便扩展,是 NoSQL 数据库产品中的一种。是最像关系型数据库 MYSQL 的非关系型和数据库

它支持的数据结构非常松散,是一种类似于 JSON 的格式,叫做 BSON , 所以它既可以存储比较复杂的数据类型,又相对灵活

Mongodb 中的记录是一个文档,它是一个由字段和值组成的数据结构,简称键值对结构,Mongodb 文档类似于 JSON 对象,即一个文档认为是一个对象,字段的数据类型是字符型,它的值除了使用基本的一些类型以外,还可以包括其他文档,普通数组和文档数组

体系结构

SQL 术语MongoDB 术语说明
databasedatabase数据库
tablecollection数据库表 / 集合
rowdocument数据记录行 / 文档
columnfield数据记录列 / 域
indexindex索引
table joins联表
嵌入文档Mongodb 通过嵌入文档来替换多表连接
primary keyprimary key主键,Mongodb 会自动将 id 设置为主键

数据模型

Mongodb 的最小单位就是文档(document)对象,文档对象对应关系型数据库的行,数据在 Mongodb 中以 BSON 格式存储数据在磁盘上

BSON

BSON (Binary Serialized Document Format) 是一种类似 json 的一种二进制形式的存储,简称 Binary JSON , BSON 和 JSON 一样支持嵌套文档对象和数组对象,但是 BSON 还多出一些数据类型,比如:Date 和 BinD艾特类型

BSON 采用了类似 C 语言结构体的名称,对表示方法,支持内嵌的文档对象和数组对象,具有轻量性,可遍历性,高效性三个特点,可以有效描述非结构化数据和结构化数据。这种格式的优点是灵活性高,但是它的缺点是空间利用率不是很理想

BSON 中,除了基本的 JSON 类型, String ,Integer ,Boolean , Double , Null , Array 和 Object 。mongo 还使用了特殊的数据类型,这些类型包括 data , object id,binary data , regularexpression 和 code 。 每一个驱动都以特定的语言方式实现了这些类型,查看你的驱动的文档来获取详细信息

BSON 数据类型

数据类型描述举例
stringUTF-8 字符串都可以表示为字符串类型的数据{“X”:"foober"}
object id对象 id 是文档的 12 字节的唯一 id{"X":ObjectId()}
booleantrue / false{"X":true}+
array值的集合或者列表可以表示成数组{“X”:["a","b","c"]}
32位整数类型不可用。js仅支持 64 位浮点数,所以该整数会被自动转换shell 也不支持,shell 会默认将其转换成 64 位
64位整数不支持这个类型,js 仅支持 64 位浮点型,shell 会使用一个特殊的内嵌文档来显示 64 位整数和上述一致
64位浮点型shell 中的数字就是这种类型{“X”:3.1415926,"y":3}
null表示空值或者未定义的对象{“x”:null}
undefined文档中也可以使用未定义类型{“x”:undefined}
符号shell 不支持,自动转换成字符型
正则表达式使用的是 js 的正则表达式规则{“x”:/doober/i}
代码文档中还可以包含 js 代码{“x”: function}
二进制数据二进制数据可以由任意字节组成,不过 shell 无法支持
最大/最小值BSON 包含一个特殊的数据类型,表示可能的最大/最小值,但是 shell 没有这个类型

shell 默认使用 64 位浮点型数值。对于整型,可以使用 Numberlnt (4 字节符号整数)或者 NumberLong (8字节长整型)

特点

高性能

Mongodb 提供高性能的数据持久化,特别是对嵌入式数据模型的支持减少了数据系统上的 I/O 活动

索引支 持更快的查询,并且可以包括孩子嵌入式文档和数据的键。(文本索引解决搜索的需求,TTL 索引解决历史数据自动过期的需求,地理位置索引可用于构建各种 O2O 应用)

mmapv1 , wiredtiger . mongorocks (rocksdb) , in-memory 等多引擎支持满足各种场景需求

Gridfs 解决文件存储需求

高可用

Mongodb 的复制工具称为副本集 ( replica set ) , 它可以提供自动故障转移和数据冗余

高扩展

Mongodb 提供了水平可扩展性作为其核心功能的一部分

分片将数据分布在一组集群的机器上。 海量数据存储,服务能力水平扩展

从 3.4 开始,Mongodb 支持基于**片键**创建数据区域。在一个平衡的集群中,MongoDB 将一个区域多覆盖的读写只定向到该区域内的那些片

丰富的查询支持

Mongodb 支持丰富的查询语言,支持读写操作(CRUD),比如数据聚合,文本搜索和地理空间查询等

其他特点

如:无模式(动态模式),灵活的文档模型

部署

参考: 在 Ubuntu 上安装 MongoDB Community Edition - MongoDB 手册 v7.0

单机部署

普通安装

MongoDB 仅支持这些平台的 64 位版本。要确定您的主机当前正在运行的 Ubuntu 版本,请在主机的终端上运行以下命令:

 root@slave03:~# cat /etc/lsb-releaseDISTRIB_ID=UbuntuDISTRIB_RELEASE=22.04DISTRIB_CODENAME=jammyDISTRIB_DESCRIPTION="Ubuntu 22.04.4 LTS"

导入公钥

 sudo apt-get install gnupg curl

要导入 MongoDB 公共 GPG 密钥,请运行以下命令:

curl -fsSL https://www.mongodb.org/static/pgp/server-7.0.asc | \sudo gpg -o /usr/share/keyrings/mongodb-server-7.0.gpg \--dearmor#

创建列表文件

为您的 Ubuntu 版本创建列表文件 /etc/apt/sources.list.d/mongodb-org-7.0.list

echo "deb [ arch=amd64,arm64 signed-by=/usr/share/keyrings/mongodb-server-7.0.gpg ] https://repo.mongodb.org/apt/ubuntu jammy/mongodb-org/7.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-7.0.list

重新加载包数据库

 sudo apt-get update

安装 MongoDB Community Server集群部署

 sudo apt-get install -y mongodb-org

如果通过软件包管理器安装,则在安装过程中会创建数据目录 /var/lib/mongodb 和日志目录 /var/log/mongodb

默认情况下,MongoDB 使用 mongodb 用户账户运行。如果更改运行 MongoDB 进程的用户,您还必须修改数据和日志目录以赋予该用户访问这些目录的权限。

配置文件

目录:/etc/mongod.conf

启动 MongoDB。

sudo systemctl start mongod

如果收到类似下方的错误

Failed to start mongod.service: Unit mongod.service not found.

首先运行以下命令

 sudo systemctl daemon-reload

再次启动

验证 MongoDB 是否已成功启动。

 sudo systemctl status mongod

开机自启动

 sudo systemctl enable mongod

开始使用 MongoDB

默认端口号为 27017

 mongosh

退出:exit

附赠一篇脚本

注意:脚本安装只限于 Ubuntu22.04 以及 CentOS8

脚本安装
#!/bin/bash
#### @Author: huangqian# @Date: 2024-09-30 17:18:03# @LastEditors: huangqian # @LastEditTime: 2024-09-30 19:05:12# @FilePath: \shellProject\数据库\mongodb_setup.sh# @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
### # define Color
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
NC='\033[0m' # null Color# logs function
log() {echo -e "$1 $YELLOW $(date '+%F %T') $NC - $2" | tee -a "/var/log/mongodb_setup.log" | sed 's/\x1b\[[0-9;]*m//g'
}# Server status function
Server_Status(){if [[ $? -ne 0 ]]; thenlog "$RED [ERROR] $NC" "$RED $1 faild $NC"exit 1;elselog "$GREEN [SUCCESS] $NC" "$GREEN $1 success $NC"fi
}# Ubuntu install mongodb function
Ubuntu_setup(){apt-get install gnupg curlServer_Status "Gnupg and curl download"# import MongoDB GPGcurl -fsSL https://www.mongodb.org/static/pgp/server-7.0.asc | sudo gpg -o /usr/share/keyrings/mongodb-server-7.0.gpg --dearmorServer_Status "Import MongoDB GPG"# Create /etc/apt/sources.list.d/mongodb-org-7.0.listecho "deb [ arch=amd64,arm64 signed-by=/usr/share/keyrings/mongodb-server-7.0.gpg ] https://repo.mongodb.org/apt/ubuntu jammy/mongodb-org/7.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-7.0.listServer_Status "Create mongodb-org-7.0.list"# Update aptapt-get updateServer_Status "Update apt"# Install MongoDB Community Serverapt-get install -y mongodb-orgServer_Status "Install mongodb-org"systemctl daemon-reload
}# Centos install mongodb function
CentOS_setup(){cat > /etc/yum.repos.d/mongodb-org-7.0.repo << EOF
[mongodb-org-7.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/8/mongodb-org/7.0/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://pgp.mongodb.com/server-7.0.asc
EOFServer_Status "mongodb-org-7.0.repo configuration"yum install -y mongodb-orgServer_Status "Install mongodb-org"yum install -y mongodb-org-7.0.14 mongodb-org-database-7.0.14 mongodb-org-server-7.0.14 mongodb-mongosh-7.0.14 mongodb-org-mongos-7.0.14 mongodb-org-tools-7.0.14Server_Status "Install MongoDB related softword package"# Auto Update softword packageexclude=mongodb-org,mongodb-org-database,mongodb-org-server,mongodb-mongosh,mongodb-org-mongos,mongodb-org-toolsServer_Status "Auto Update softword package"chown -R mongod:mongod /var/log/mongodb# Install SELinux strategyyum install git make checkpolicy policycoreutils selinux-policy-develServer_Status "Install SELinux strategy"which gitif [ $? -eq 0 ];thengit clone https://github.com/mongodb/mongodb-selinuxServer_Status "SELinux strategy clone"cd mongodb-selinuxmake && make installServer_Status "make && make install"elselog "$RED [ERROR] $NC" "git uninstall or not configuration PATH"fi
}info(){echo "$GREEN Enter [ systemctl start mongod ] start MongoDB $NC"echo "$GREEN Enter [ systemctl status mongod ] check status MongoDB $NC"echo "$GREEN Enter [ systemctl enable mongod ] starting Up start MongoDB $NC"echo "$GREEN Check MongoDB logs [ cat /var/log/mongodb_setup.log ] $NC"
}# Confirm system version
SysVersion(){local SYSTEM_VERSION=$(cat /etc/lsb-release | awk 'NR==2');if [[ $SYSTEM_VERSION = 'DISTRIB_RELEASE=22.04' ]];then# Start installlog "$YELLOW [INFO] $NC" "$YELLOW  Ubuntu install ... $NC"Ubuntu_setupelselog "$YELLOW [INFO] $NC" "$YELLOW CentOS install ... $NC"CentOS_setupfi
}main(){SysVersioninfo
}main
Docker Compose 安装

创建数据目录

 mkdir -p /root/mongo/data

docker-compose.yml

services:mongodb:container_name: mymongoimage: mongo:latestrestart: alwaysports:- "27017:27017"environment:- MONGO_INITDB_ROOT_USERNAME=root- MONGO_INITDB_ROOT_PASSWORD=rootvolumes:- /root/mongo/data:/data/dbcommand:- "--auth"

启动

 docker compose up -d

后续的使用和上诉安装之后是一致的

卸载

docker 版本的如何卸载不用过多赘述

停止 MongoDB

sudo service mongod stop

删除包

sudo apt-get purge "mongodb-org*"

删除数据目录

sudo rm -r /var/log/mongodb
sudo rm -r /var/lib/mongodb

有关副本集群的搭建请跳转至:链接:https://blog.csdn.net/qq_62866151/article/details/142671701?sharetype=blogdetail&sharerId=142671701&sharerefer=PC&sharesource=qq_62866151&spm=1011.2480.3001.8118

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python全栈学习记录(二十一)类的继承、派生、组合

类的继承、派生、组合 文章目录 类的继承、派生、组合一、类的继承二、派生三、组合 一、类的继承 继承是一种新建类的方式&#xff0c;新建的类称为子类&#xff0c;被继承的类称为父类。 继承的特性是&#xff1a;子类会遗传父类的属性&#xff08;继承是类与类之间的关系&a…

2024年研究生数学建模“华为杯”E题——肘部法则、k-means聚类、目标检测(python)、ARIMA、逻辑回归、混淆矩阵(附:目标检测代码)

文章目录 一、情况介绍二、思路情况二、代码展示三、感受 一、情况介绍 前几天也是参加了研究生数学建模竞赛&#xff08;也就是华为杯&#xff09;&#xff0c;也是和本校的两个数学学院的朋友在网上组的队伍。昨天&#xff08;9.25&#xff09;通宵干完论文&#xff08;一条…

Prompt 初级版:构建高效对话的基础指南

Prompt 初级版&#xff1a;构建高效对话的基础指南 文章目录 Prompt 初级版&#xff1a;构建高效对话的基础指南一 “标准”提示二 角色提示三 多范例提示四 组合提示五 规范化提示 本文介绍了提示词的基础概念与不同类型&#xff0c;帮助用户更好地理解如何在对话中构建有效的…

Pytorch实现玉米基因表达量预测模型

一、实验要求 通过搭建残差卷积网络&#xff0c;实现对玉米基因表达量的预测 二、实验目的 理解基因表达量预测问题&#xff1a;基因表达预测是生物信息学和基因组学领域中的重要任务之一&#xff0c;促进学科交叉融合。熟悉深度学习框架PyTorch&#xff1a;通过实现基因表达量…

css 数字比汉字要靠上

这个问题通常是由于数字字体的下排的问题造成的&#xff0c;也就是数字的底部边缘位置比汉字的顶部边缘位置更靠下。为了解决这个问题&#xff0c;可以尝试以下几种方法&#xff1a; 使用CSS的vertical-align属性来调整对齐方式。例如&#xff0c;可以将数字的对齐方式设置为to…

Linux高级编程_27_系统调用

文章目录 系统调用函数分类系统编程概述系统调用概述**类UNIX系统的软件层次** 用户态和内核态系统调用与库函数的关系文件操作符概述文件磁盘权限 系统调用之文件操作open:打开文件close:关闭文件write:写入read:读取 文件状态fcntl 函数stat 函数 st_mode的值示例 1&#xff…

【优选算法之队列+宽搜/优先级队列】No.14--- 经典队列+宽搜/优先级队列算法

文章目录 前言一、队列宽搜示例&#xff1a;1.1 N 叉树的层序遍历1.2 ⼆叉树的锯⻮形层序遍历1.3 ⼆叉树最⼤宽度1.4 在每个树⾏中找最⼤值 二、优先级队列&#xff08;堆&#xff09;示例&#xff1a;2.1 最后⼀块⽯头的重量2.2 数据流中的第 K ⼤元素2.3 前 K 个⾼频单词2.4 …

数造科技入选中国信通院《高质量数字化转型产品及服务全景图》三大板块

9月24日&#xff0c;2024大模型数字生态发展大会暨“铸基计划”年中会议在北京召开。会上&#xff0c;中国信通院发布了2024年《高质量数字化转型产品及服务全景图&#xff08;上半年度&#xff09;》和《高质量数字化转型技术解决方案&#xff08;上半年度&#xff09;》等多项…

网络编程篇:UDP协议

一 UDP协议格式 16位源端口号&#xff1a;表示数据从哪里来。16位目的端口号&#xff1a;表示数据要到哪里去。16位UDP长度&#xff1a;表示整个数据报&#xff08;UDP首部UDP数据&#xff09;的长度。16位UDP检验和&#xff1a;如果UDP报文的检验和出错&#xff0c;就会直接将…

【Kubernetes】常见面试题汇总(五十三)

目录 118. pod 状态为 ErrlmagePull &#xff1f; 119.探测存活 pod 状态为 CrashLoopBackOff &#xff1f; 特别说明&#xff1a; 题目 1-68 属于【Kubernetes】的常规概念题&#xff0c;即 “ 汇总&#xff08;一&#xff09;~&#xff08;二十二&#xff09;” 。…

MongoDB聚合操作及索引底层原理

目录 链接:https://note.youdao.com/ynoteshare/index.html?id=50fdb657a9b06950fa255a82555b44a6&type=note&_time=1727951783296 本节课的内容: 聚合操作: 聚合管道操作: ​编辑 $match 进行文档筛选 ​编辑 将筛选和投影结合使用: ​编辑 多条件匹配: …

Springboot + netty + rabbitmq + myBatis

目录 0.为什么用消息队列1.代码文件创建结构2.pom.xml文件3.三个配置文件开发和生产环境4.Rabbitmq 基础配置类 TtlQueueConfig5.建立netty服务器 rabbitmq消息生产者6.建立常规队列的消费者 Consumer7.建立死信队列的消费者 DeadLetterConsumer8.建立mapper.xml文件9.建立map…

King3399 SDK(ubuntu文件系统)编译简明教程

该文章仅供参考&#xff0c;编写人不对任务实验设备、人员及测量结果负责&#xff01;&#xff01;&#xff01; 0 引言 文章主要介绍King3399&#xff08;瑞芯微rk3399开发板&#xff0c;荣品&#xff09;官方SDK&#xff08;Ubuntu文件系统&#xff09;编译过程&#xff0c…

【本地免费】SimpleTex 图像识别latex公式

文章目录 相关教程相关文献安装教程 由于mathpix开始收费了&#xff0c;于是本文将介绍一款目前本地免费的SimpleTex工具 相关教程 【超详细安装教程】LaTeX-OCR 图像识别latex公式&#xff08;开源免费&#xff09;_latex图片识别-CSDN博客 相关文献 SimpleTex主页——致力…

Elasticsearch使用Easy-Es + RestHighLevelClient实现深度分页跳页

注意&#xff01;&#xff01;&#xff01;博主只在测试环境试了一下&#xff0c;没有发到生产环境跑。因为代码还没写完客户说不用弄了( •̩̩̩̩&#xff3f;•̩̩̩̩ ) 也好&#xff0c;少个功能少点BUG 使用from size的时候发现存在max_result_window10000的限制&…

薄膜凸起和开裂是同一种应力导致的吗?

知识星球里的学员问&#xff1a;我们产线上薄膜出了质量问题&#xff0c;都一概归结为应力过大。麻烦讲讲应力的种类&#xff0c;以及不同种类的应力会造成哪些薄膜问题&#xff1f; 内应力的种类&#xff1f; 内应力的分类很多&#xff0c;如果我们按作用的效果来分&#xff…

树莓派 AI 摄像头(Raspberry Pi AI Camera)教程

系列文章目录 前言 人们使用 Raspberry Pi 产品构建人工智能项目的时间几乎与我们生产 Raspberry Pi 的时间一样长。随着我们发布功能越来越强大的设备&#xff0c;我们能够支持的原生应用范围也在不断扩大&#xff1b;但无论哪一代产品&#xff0c;总会有一些工作负载需要外部…

嵌入式外设应用(代码)

文章目录 1. 工业自动化2. 智能家居设备3. 汽车电子4. 生命体征监测仪5. 物联网应用 嵌入式外设应用广泛&#xff0c;有很多应用领域&#xff1a; 1. 工业自动化 应用场景&#xff1a;使用传感器监测设备状态&#xff0c;控制电机的启动和停止。 示例代码&#xff1a; #inc…

Stream流的终结方法(二)——collect

1.Stream流的终结方法 2. collect方法 collect方法用于收集流中的数据放到集合中去&#xff0c;可以将流中的数据放到List&#xff0c;Set&#xff0c;Map集合中 2.1 将流中的数据收集到List集合中 package com.njau.d10_my_stream;import java.util.*; import java.util.f…

SSL VPN | Easyconnect下载安装使用 (详尽)

EasyConnect是一款远程连接工具&#xff0c;为用户提供简便、快捷的远程访问和控制解决方案。 目录 下载 安装 使用 卸载 下载 通过链接进入官网技术支持板块 深信服技术支持-简单、高效、自助化服务 (sangfor.com.cn)https://support.sangfor.com.cn/ 选择软件下载 在安…