一、MongoDB 介绍
1、基本概念
- MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSQL数据库产品中最热门的一种。
- 它在许多场景下可用于替代传统的关系型数据库或键/值存储方式, MongoDB使用C++开发。
- MongoDB的官方网站地址是: http://www.mongodb.org/,大家可以在此获得更详细的信息。
- MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
- 他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。
- MongoDB最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
- 它是一个面向集合的,模式自由的文档型数据库。
MongoDB特点及其使用范围
- MongoDB的主要目标是在键/值存储方式(提供了高性能和高度伸缩性)以及传统的RDBMS系统(丰富的功能)架起一座桥梁,集两者的优势于一身。根据官方网站的描述, Mongo适合用于以下场景:
- 网站数据:Mongo非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
- 缓存:由于性能很高,Mongo也适合作为信息基础设施的缓存层。在系统重启之后,由Mongo搭建的持久化缓存层可以避免下层的数据源过载。
- 大尺寸,低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储。
- 高伸缩性的场景:Mongo非常适合由数十或数百台服务器组成的数据库。Mongo的路线图中已经包含对MapReduce引擎的内置支持。
- 用于对象及JSON数据的存储:Mongo的BSON数据格式非常适合文档化格式的存储及查询。
- MongoDB的使用也会有一些限制,例如它不适合:
- 高度事务性的系统:例如银行或会计系统。传统的关系型数据库目前还是更适用于需要大量原子性复杂事务的应用程序。
- 传统的商业智能应用:针对特定问题的BI数据库会对产生高度优化的查询方式。对于此类应用,数据仓库可能是更合适的选择。
- 需要SQL的问题
2、对比
二、mongodb安装
1、配置yum
2、安装
下载软件包
mongodb-linux-x86_64-2.6.0.tgz
3、修改配置文件
4、启动mongodb
三、mongodb 主备搭建(目前常用复制集代替主备)
- 前提确保防火墙开通
1、主机器(master)
2、从机器(slave)
- 注意:这里可以使用mongodump或者scp命令把主机器的mongodb的所有目录和文件远程拷贝到从机器上去,之前不要去启动,主机器,否则启动从的时候会报错
- (在日志文件中可以看到错误:mongodb ERROR: Client::~Client _context should be null but is not;client:replslave)
- 这样的话, 只需要把数据文件data目录下的所有文件删除,重新启动即可