MongoDB特点及功能介绍

本文介绍了MongoDB的特点,如高性能、无模式的文档型数据库,适合实时查询、高伸缩性场景。同时,文章详细阐述了MongoDB的安装步骤,包括配置yum、安装、启动,以及如何搭建主备复制集,包括主从机器的配置、测试。此外,还提及了常用命令、优化器Profiler和问题定位等内容。
摘要由CSDN通过智能技术生成

一、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

1
$ vim /etc/yum.repos.d/mongodb.repo
2
[mongodb]
3
name=MongoDB Repository
4
baseurl=http://downloads-distro.mongodb.org/repo/redhat/os/x86_64/
5
gpgcheck=0
6
enabled=1

2、安装

1
$ yum install mongo-10gen mongo-10gen-server
下载软件包 mongodb-linux-x86_64-2.6.0.tgz
1
$ tar zxf mongodb-linux-x86_64-2.6.0.tgz -C /usr/local/
2
$ mv /usr/local/mongodb-linux-x86_64-2.6.0 /usr/local/mongodb
3
$ vim /root/.bash_profile
4
PATH=$PATH:$HOME/bin:/usr/local/mongodb/bin
5
. /root/.bash_profile

3、修改配置文件

1
$ vim /etc/mongod.conf
2
dbpath=/home/mongodb    #数据库路径
3
logpath=/home/mongodb/mongod.log    #日志文件路径
4
logappend=true    #日志文件末尾添加(追加日志方式)
5
fork = true    #在后台运行
6
port = 27017    #端口
7
#keyFile = /data/mongodb/key/key_20001    #复制集keyfile文件
8
pidfilepath = /home/mongodb/mongod.pid    #pid文件路径
9
#master = true    #指定为主机器,如果是从则为slave = true
10
source = 127.0.0.1    #指定主机器的IP地址,如果是主source =127.0.0.1
11
auth = true    #用户验证
12
directoryperdb = true    #单独数据库目录
13
#slavedelay= 10    #从库配置,指从复制检测的时间间隔
14
#replSet = rsmongo    #复制集名称
15
directoryperdb = true    #创建数据目录
16
#bind_ip = 10.25.36.20    #绑定IP

4、启动mongodb

1
$ mongod -f /etc/mongod.conf
2
3
$ mongod --config=/etc/mongod.conf

三、mongodb 主备搭建(目前常用复制集代替主备)

  • 前提确保防火墙开通

1、主机器(master)

1
master: 172.16.101.251
2
mongodb home: /home/mongodb
3
data file: /home/mongodb
4
log file: /home/mongodb

2、从机器(slave)

1
slave: 172.16.101.244
2
mongodb home: /home/mongodb/
3
data file: /home/mongodb
4
log file: /home/mongodb
  • 注意:这里可以使用mongodump或者scp命令把主机器的mongodb的所有目录和文件远程拷贝到从机器上去,之前不要去启动,主机器,否则启动从的时候会报错
  • (在日志文件中可以看到错误:mongodb ERROR: Client::~Client _context should be null but is not;client:replslave)
  • 这样的话, 只需要把数据文件data目录下的所有文件删除,重新启动即可

3、修改配置文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值