伴随着互联网应用的迅猛推广和各种开源产品的深入,各种非关系型数据NoSQL产品近几年的发展比较迅猛。针对特定行业、领域和应用场景,脱离关系型数据模型体系的NoSQL家族,已经逐步深入各行各业,逐步被技术应用领域所接受。
MongoDB由于自身基于文档(Document)和灵活的Schema策略模型,以及较为成熟的管理应用功能体系和开源特性,在国内正变得越来越流行,成为IT数据架构选型的标准之一。本篇主要介绍在Linux操作系统体系下,进行简单的MongoDB安装方法。
1、环境介绍
Linux环境下的应用安装,主要有几种标准方式:yum类型一体式安装,设置好repository,最新版本安装和依赖包一气呵成;自己解决包依赖问题,使用rpm甚至zip压缩文件直接安装;最后一种比较“高级”,是获取到软件源代码,在操作系统层面直接编译安装。本篇中,笔者使用第二种压缩文件的方式,进行基础安装。环境使用Red Hat Enterprise Linux6.5版本。
[root@Oracle-test /]# cat /etc/RedHat-release
Red Hat Enterprise Linux Server release 6.5 (Santiago)
从MongoDB官方网站下载到对应的安装文件。
[root@oracle-test upload]# ls -l
total 98124
-rw-r--r--. 1 root root 100477926 Jul 13 22:39 mongodb-linux-x86_64-rhel62-3.4.5.tgz
2、安装系统
同Oracle和MySQL一样,我们尽量不使用root用户作为数据库运行主体。最好创建专门的数据库用户帐号。
[root@oracle-test /]# groupadd mongodb
[root@oracle-test /]# useradd -g mongodb mongodb
[root@oracle-test /]# id mongodb
uid=501(mongodb) gid=501(mongodb) groups=501(mongodb)
创建单独的目录,防止解压文件。
[root@oracle-test /]# mkdir /mongodb
[root@oracle-test /]# chown -R mongodb:mongodb mongodb
[root@oracle-test /]# ls -l | grep mongodb
drwxr-xr-x. 2 mongodb mongodb 4096 Jul 13 22:38 mongodb
[root@oracle-test upload]# cp mongodb-linux-x86_64-rhel62-3.4.5.tgz /mongodb/
解压文件:
[root@oracle-test mongodb]# tar zxvf mongodb-linux-x86_64-rhel62-3.4.5.tgz
mongodb-linux-x86_64-rhel62-3.4.5/README
(篇幅原因,有省略……)
mongodb-linux-x86_64-rhel62-3.4.5/bin/mongod
mongodb-linux-x86_64-rhel62-3.4.5/bin/mongos
mongodb-linux-x86_64-rhel62-3.4.5/bin/mongo
设置数据库用户帐号权限。
[root@oracle-test mongodb]# chown -R mongodb:mongodb *
[root@oracle-test mongodb]# ls -l
total 4
drwxr-xr-x. 3 mongodb mongodb 4096 Jul 13 22:41 mongodb-linux-x86_64-rhel62-3.4.5
进入解压目录,就可以看到主要的bin文件夹,包括了大部分的功能组件。其中,mongod是数据库实例运行程序进程,是Mongodb的核心。Mongo也称为mongo shell,是类似于sqlplus的客户端程序。其他诸如导入导出、备份还原,基本与其他商用数据库差异不大。
[root@oracle-test mongodb-linux-x86_64-rhel62-3.4.5]# cd bin
[root@oracle-test bin]# ls -l
total 277044
-rwxr-xr-x. 1 mongodb mongodb 10359081 Jun 14 05:37 bsondump
-rwxr-xr-x. 1 mongodb mongodb 29860072 Jun 14 06:02 mongo
-rwxr-xr-x. 1 mongodb mongodb 54387648 Jun 14 06:02 mongod
-rwxr-xr-x. 1 mongodb mongodb 12696783 Jun 14 05:38 mongodump
-rwxr-xr-x. 1 mongodb mongodb 10711297 Jun 14 05:38 mongoexport
-rwxr-xr-x. 1 mongodb mongodb 10593233 Jun 14 05:37 mongofiles
-rwxr-xr-x. 1 mongodb mongodb 10867956 Jun 14 05:38 mongoimport
-rwxr-xr-x. 1 mongodb mongodb 10361065 Jun 14 05:38 mongooplog
-rwxr-xr-x. 1 mongodb mongodb 53756680 Jun 14 06:02 mongoperf
-rwxr-xr-x. 1 mongodb mongodb 14000016 Jun 14 05:39 mongoreplay
-rwxr-xr-x. 1 mongodb mongodb 14054073 Jun 14 05:38 mongorestore
-rwxr-xr-x. 1 mongodb mongodb 30523368 Jun 14 06:02 mongos
-rwxr-xr-x. 1 mongodb mongodb 10931198 Jun 14 05:37 mongostat
-rwxr-xr-x. 1 mongodb mongodb 10557955 Jun 14 05:38 mongotop
3、运行和连接数据库
为了方便起见,将mongodb的bin路径,添加到mongodb用户的PATH变量中。
[root@oracle-test bin]# su - mongodb
[mongodb@oracle-test ~]$ vi .bash_profile
PATH=$PATH:$HOME/bin
PATH=$PATH:/mongodb/mongodb-linux-x86_64-rhel62-3.4.5/bin
export PATH
~
第一次启动,直接从命令行中执行mongod命令,启动数据库。
[mongodb@oracle-test ~]$ mongod
2017-07-13T22:47:36.872+0800 I CONTROL [initandlisten] MongoDB starting : pid=18996 port=27017 dbpath=/data/db 64-bit host=oracle-test
2017-07-13T22:47:36.872+0800 I CONTROL [initandlisten] db version v3.4.5
2017-07-13T22:47:36.872+0800 I CONTROL [initandlisten] git version:
(篇幅原因,有省略……)
2017-07-13T22:47:36.872+0800 I STORAGE [initandlisten] exception in initAndListen: 29 Data directory /data/db not found., terminating
2017-07-13T22:47:36.872+0800 I NETWORK [initandlisten] shutdown: going to close listening sockets...
2017-07-13T22:47:36.872+0800 I NETWORK [initandlisten] shutdown: going to flush diaglog...
2017-07-13T22:47:36.872+0800 I CONTROL [initandlisten] now exiting
2017-07-13T22:47:36.872+0800 I CONTROL [initandlisten] shutting down with code:100