简介
MongoDB是一个开源、高性能、支持海量数据存储的文档型数据库
是NoSQL数据库产品中的一种,是最像关系型数据库(MySQL)的非关系型数据库
内部采用BSON(二进制JSON)格式来存储数据,并支持水平扩展。
MongoDB本身并不是完全免费的,它对于一些商业场景是收费的。
MongoDB的收费条款和价格因版本、支持类型和付费周期而异。
特点
数据存储量较大,甚至是海量
对数据读写的响应速度要求较高
某些数据安全性要求不高,可以接受一定范围内的误差
内部实现
与redis和mysql对比
与Redis的对比
Redis纯内存数据库,内存不足触发淘汰策略
结构化存储格式(Bson),方便扩展
与MySQL的对比
MongoDB不支持事务和多表操作
MongoDB支持动态字段管理
查询效率对比
Redis > MongoDB > MySQL
使用场景
游戏装备数据、游戏道具数据
特征:修改频度较高
物流行业数据
特征:地理位置信息,海量数据
直播数据、打赏数据、粉丝数据
特征:数据量大,修改频度极高
日志数据
特征:数据量巨大,结构多变
docker安装mongoDB
# 拉去镜像
docker pull mongo
# 运行镜像
docker run -itd --name mongo -p 27017:27017 -v ~/data/mongodata:/data mongo --auth
# 进入MongoDB命令行
docker exec -it mongo bash
docker exec -it mongo mongosh admin
# 创建用户
db.createUser({ user:'admin',pwd:'123456.',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
# 测试用户连接
db.auth('admin', '123456.')