响应式网站设计公司,宁波网站建设公司地址,佛山市网络推广,国际新闻最新消息2022一#xff1a;MongoDB数据库
1.1 简介
MongoDB是一个开源、高性能、无模式的文档型数据库#xff0c;当初的设计就是用于简化开发和方便扩展#xff0c;是NoSQL数据库产品中的一种。是最 像关系型数据库#xff08;MySQL#xff09;的非关系型数据库。
它支持的数据结构…一MongoDB数据库
1.1 简介
MongoDB是一个开源、高性能、无模式的文档型数据库当初的设计就是用于简化开发和方便扩展是NoSQL数据库产品中的一种。是最 像关系型数据库MySQL的非关系型数据库。
它支持的数据结构非常松散是一种类似于 JSON 的 格式叫BSON所以它既可以存储比较复杂的数据类型又相当的灵活。
MongoDB中的记录是一个文档它是一个由字段和值对field:value组成的数据结构。MongoDB文档类似于JSON对象即一个文档认 为就是一个对象。字段的数据类型是字符型它的值除了使用基本的一些类型外还可以包括其他文档、普通数组和文档数组。
1.2 体系结构
MySQL和MongoDB对比
1.3 MongoDB的使用场景
1.3.1 传统数据库如MySql的三高需求
• 对数据库高并发读写的需求。 • 对海量数据的高效率存储和访问的需求。 • 对数据库的高可扩展性和高可用性的需求。
1.3.2 MongoDB的具体的应用场景
1社交场景使用 MongoDB 存储存储用户信息以及用户发表的朋友圈信息通过地理位置索引实现附近的人、地点等功能。 2游戏场景使用 MongoDB 存储游戏用户信息用户的装备、积分等直接以内嵌文档的形式存储方便查询、高效率存储和访问。 3物流场景使用 MongoDB 存储订单信息订单状态在运送过程中会不断更新以 MongoDB 内嵌数组的形式来存储一次查询就能将订单所有的变更读取出来。 4物联网场景使用 MongoDB 存储所有接入的智能设备信息以及设备汇报的日志信息并对这些信息进行多维度的分析。 5视频直播使用 MongoDB 存储用户信息、点赞互动信息等。
这些应用场景中数据操作方面的共同特点是 1数据量大 2写入操作频繁读写都很频繁 3价值较低的数据对事务性要求不高 对于这样的数据我们更适合使用MongoDB来实现数据的存储。
1.3.3 什么时候选择MongoDB
在架构选型上除了上述的三个特点外如果你还犹豫是否要选择它可以考虑以下的一些问题
应用不需要事务及复杂 join 支持新应用需求会变数据模型无法确定想快速迭代开发应用需要2000-3000以上的读写QPS更高也可以应用需要TB甚至 PB 级别数据存储应用发展迅速需要能快速水平扩展应用要求存储的数据不丢失应用需要99.999%高可用应用需要大量的地理位置查询、文本查询
如果上述有1个符合可以考虑 MongoDB2个及以上的符合选择 MongoDB 绝不会后悔。
1.4 MongoDB的特点
1高性能 MongoDB提供高性能的数据持久性。特别是对嵌入式数据模型的支持减少了数据库系统上的I/O活动。索引支持更快的查询并且可以包含来自嵌入式文档和数组的键。文本索引解决搜索的需求、TTL索引解决历史数据自动过期的需求、地理位置索引可用于构建各种 O2O 应用mmapv1、wiredtiger、mongorocksrocksdb、in-memory 等多引擎支持满足各种场景需求。Gridfs解决文件存储的需求。 2高可用性 MongoDB的复制工具称为副本集replica set它可提供自动故障转移和数据冗余。 3高扩展性 MongoDB提供了水平可扩展性作为其核心功能的一部分。 分片将数据分布在一组集群的机器上。海量数据存储服务能力水平扩展 从3.4开始MongoDB支持基于片键创建数据区域。在一个平衡的集群中MongoDB将一个区域所覆盖的读写只定向到该区域内的那些 片。 4丰富的查询支持 MongoDB支持丰富的查询语言支持读和写操作(CRUD)比如数据聚合、文本搜索和地理空间查询等。
二docker容器安装mongoDB数据库
2.1 拉取镜像 docker pull mongo:4.0.3 2.2 创建容器 docker create --name mongodb-server -p 27017:27017 -v mongodb-data:/data/db mongo:4.0.3 --auth 2.3 启动容器并进入容器
docker start mongodb-server #启动容器docker exec -it mongodb-server /bin/bash #进入容器2.4 进入admin数据库 mongo use admin 2.5 添加管理员其拥有管理用户和角色的权限
添加用户 db.createUser({ user: ‘root’, pwd: ‘root’, roles: [ { role: “root”,db: “admin” } ] }) 退出 exit 2.6 进行认证 mongo -u ‘root’ -p ‘root’ --authenticationDatabase ‘admin’ 2.7 通过admin添加普通用户 use admin db.createUser({ user: ‘house’, pwd: ‘oudqBFGmGY8pU6WS’, roles: [ {role: ‘readWrite’, db: ‘house’ } ] }); 2.8 进入到house数据库 mongo -u ‘house’ -p ‘oudqBFGmGY8pU6WS’ --authenticationDatabase ‘admin’