MongoDB入门

简介

MongoDB是一个开源、高性能、支持海量数据存储的文档型数据库

是NoSQL数据库产品中的一种,是最像关系型数据库(MySQL)的非关系型数据库

内部采用BSON(二进制JSON)格式来存储数据,并支持水平扩展。

MongoDB本身并不是完全免费的,它对于一些商业场景是收费的。

MongoDB的收费条款和价格因版本、支持类型和付费周期而异。

特点

数据存储量较大,甚至是海量

对数据读写的响应速度要求较高

某些数据安全性要求不高,可以接受一定范围内的误差

内部实现

与redis和mysql对比

与Redis的对比

Redis纯内存数据库,内存不足触发淘汰策略

结构化存储格式(Bson),方便扩展
与MySQL的对比

MongoDB不支持事务和多表操作

MongoDB支持动态字段管理
查询效率对比

Redis > MongoDB > MySQL

使用场景

游戏装备数据、游戏道具数据

特征:修改频度较高
物流行业数据

特征:地理位置信息,海量数据
直播数据、打赏数据、粉丝数据

特征:数据量大,修改频度极高
日志数据

特征:数据量巨大,结构多变

docker安装mongoDB

bash 复制代码
docker pull mongo

docker run -itd --name mongo -p 27017:27017  -v ~/data/mongodata:/data  mongo --auth

-p 27017:27017 :映射容器服务的 27017 端口到宿主机的 27017 端口。外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务。
--auth:需要密码才能访问容器服务。
相关推荐
数据智能老司机12 小时前
CockroachDB权威指南——CockroachDB SQL
数据库·分布式·架构
数据智能老司机13 小时前
CockroachDB权威指南——开始使用
数据库·分布式·架构
松果猿13 小时前
空间数据库学习(二)—— PostgreSQL数据库的备份转储和导入恢复
数据库
无名之逆13 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
s91236010113 小时前
rust 同时处理多个异步任务
java·数据库·rust
数据智能老司机13 小时前
CockroachDB权威指南——CockroachDB 架构
数据库·分布式·架构
hzulwy14 小时前
Redis常用的数据结构及其使用场景
数据库·redis
程序猿熊跃晖14 小时前
解决 MyBatis-Plus 中 `update.setProcInsId(null)` 不生效的问题
数据库·tomcat·mybatis
Three~stone15 小时前
MySQL学习集--DDL
数据库·sql·学习
Qi妙代码15 小时前
MYSQL基础
数据库·mysql·oracle