设为首页 收藏本站
查看: 1010|回复: 0

[经验分享] MongoDB实战(1)MongoDB安装与存储结构

[复制链接]

尚未签到

发表于 2018-10-27 10:43:08 | 显示全部楼层 |阅读模式
  一、linux平台的安装
wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.4.8.tgz  
tar -zxvf mongodb-linux-x86_64-2.4.8.tgz
  
#创建数据存放目录和日志目录
  
/data/db
  
/data/log/mongo.log
  
#启动mongod服务进程 --fork后台运行
  
/mongodb/bin/mongod --dbpath=/data/db --logpath=/data/log/mongo.log --fork
  然后可以进入mongodb客户端进行测试了
/mongodb/bin/mongo
DSC0000.png

  二、数据逻辑结构
  MongoDB的文档document相当于关系数据库中的一行记录。
  多个文档组成一个集合collection相当于关系数据库的表。
  多个集合collection逻辑上组织在一起就是数据库database。
  一个MongoDB实例支持多个数据库database。
  文档(document)、集合(collection)、数据库(database)的层次结构如下图:
DSC0001.png

  对于习惯了关系型数据库的朋友们我将MongoDB与关系型数据库的逻辑结构进行了对比
  以便让大家更深刻的理解MongoDB的逻辑结构
DSC0002.png

  MongoDB的默认数据目录是/data/db它负责存储所有的MongoDB的数据文件。在MongoDB
  内部每个数据库都包含一个.ns文件和一些数据文件而且这些数据文件会随着数据量的
  增加而变得越来越多。所以如果系统中有一个叫做test的数据库那么构成test这个数据库
  的文件就会由test.nstest.0test.1test.2等等组成具体如下:
DSC0003.png

  数据库的每张表都对应一个命名空间每个索引也有对应的命名空间。这些命名空间的元数
  据都集中在*.ns文件中。
  MongoDB内部有预分配空间的机制每个预分配的文件都从*.0开始由于有了这个机
  制,MongoDB始终保持额外的空间和空余的数据文件从而有效避免了由于数据暴增而带来
  的磁盘压力过大的问题。
  由于表中数据量的增加数据文件每新分配一次它的大小都会是上一个数据文件大小的2
  倍所以我们看到test.1的大小是test.0的2倍。每个数据文件最大2G。这样的机制有利于防止较小的数据库浪费过多的磁盘空间同时又能保证较大的数据库有相应的预留空间使用。
  当命名空间需要分配新的文件的时候都会先检查是否有已经删除的大小合适的盘区可以使用这样就回收空闲的磁盘空间了。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-627044-1-1.html 上篇帖子: mongodb管理与安全认证 下篇帖子: MongoDB实战(2)工具集与特殊魔术方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表