数据库

 首页 > 数据库 > MongoDB > Debian Linux系统安装配置 MongoDB数据库过程

Debian Linux系统安装配置 MongoDB数据库过程

分享到:
【字体:
导读:
         摘要:mongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似...

Debian Linux系统安装配置 MongoDB数据库过程
mongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:

    面向集合存储,易存储对象类型的数据。
    模式自由。
    支持动态查询。
    支持完全索引,包含内部对象。
    支持查询。
    支持复制和故障恢复。
    使用高效的二进制数据存储,包括大型对象(如视频等)。
    自动处理碎片,以支持云计算层次的扩展性
    支持Ruby,Python,JAVA,C++,PHP等多种语言。
    文件存储格式为BSON(一种JSON的扩展)
    可通过网络访问

本文主要讲述在 Ubuntu Linux 安装配置 MongoDB 步骤:

一、在Ubuntu下最傻瓜的步骤(以下都在root用户下进行操作):

1. 运行"apt-get install mongo",如果遇到找不到安装包的话运行"apt-get update"。

# apt-get install mongo

2. 这时装好以后应该会自动运行mongod程序,通过"pgrep mongo -l "查看进程是否已经启动。

# pgrep mongo -l

3 .在终端输入"mongo",然后回车进入数据库。

# mongo

下面说下如何自己启动mongodb的程序。

二、重启系统以后mongo程序要自己重新手动启动,步骤如下:

1. 运行“locate mongo”命令查看系统默认把mongo装到了哪里,这里主要关注三个东西。

# locate mongo

    一个是名为“mongod”的程序的位置(他相当于mongo数据库的Server,需要一直在后台运行,我的路径:/usr/bin/mongod);
    一个是mongo 数据库log日志文件的位置(log日志文件要查看到具体的文件名,具体用法在后面有介绍,我的路径:/var/log/mongodb/mongodb.log);
一个是mongo的log日志的位置(我的路径:/var/log/mongodb/mongodb.log)。

2. 先进入mongod所在的目录(/usr/bin/mongod),然后运行“./mongod --dbpath /var/lib/mongodb/ --logpath /var/log/mongodb/mongodb.log --logappend &”

# cd /usr/bin/mongod
# ./mongod --dbpath /var/lib/mongodb/ --logpath /var/log/mongodb/mongodb.log --logappend &

    --dbpath:指定mongo的数据库文件在哪个文件夹。
--logpath:指定mongo的log日志是哪个,这里log一定要指定到具体的文件名。
    --logappend:表示log的写入是采用附加的方式,默认的是覆盖之前的文件。
    &:表示程序在后台运行。

注意:如果是系统非正常关闭,这样启动会报错,由于mongodb自动被锁上了,这是需要进入mongodb数据库文件所在的目录(/var/lib/mongodb/),删除目录中的mongodb.lock文件,然后再进行上述操作。

安装好以后就可以通过编写C++程序进行相应的数据库操作了,下面介绍一下编写简单的连接mongo的C++程序以及如果解决mongo动态库链接失败的情况:

一、安装好mongo数据库以后,创建一个用来链接数据库的简单C++程序mon2.cpp,发现很多网站都用这个程序做示例。

不过重点在于如何让这个程序真正可以跑起来显示出来结果,着实费了一番功夫。

#include  #include "client/dbclient.h"  using namespace mongo; using namespace std; void run() { DBClientConnection c; c.connect("localhost"); }  int main() { try { run(); cout << "connected ok" << endl; } catch( DBException &e ) { cout << "caught " << e.what() << endl; } return 0; }
在终端输入“g++ mon2.cpp -I /usr/include/mongo/ /usr/lib/libmongoclient.a -lboost_thread -lboost_filesystem -lboost_program_options”进行编译C++程序。

# g++ mon2.cpp -I /usr/include/mongo/ /usr/lib/libmongoclient.a -lboost_thread -lboost_filesystem -lboost_program_options

”-lboost_thread -lboost_filesystem -lboost_program_options“这三个是编译关于mongo的C++程序需要用到的动态库,问题往往出现在这里,涉及到数据库的程序编译不通过,八成是找不到对应的动态库文件。

二、解决编译C++程序时链接mongo的动态库失败的问题

最简单的解决办法:

在root用户下,首先进入mongo的库目录(我的路径是"/usr/lib"),然后在终端输入"ls -al | grep libboost"查找相应的动态链接库文件,如果找不到以".so"结尾文件,则拷贝("cp 源文件 目标文件")下面显示的七个动态库到当前目录,并且命名为"xxx.so" ,或者创建这七个动态库的软链接到当然目录(会在下面提到)。

# cd /usr/lib
# ls -al | grep libboost
# cp 源文件 目标文件

然后修改"/etc/ld.so.conf"文件,增加一行刚才存放.so文件的目录的地址,如下图则增加一行"/usr/lib"

include /etc/ld.so.conf/*.conf /usr/lib
保存完以后,运行"ldconfig"命令使配置生效。

# ldconfig

以上已经达到了可以运行编译的条件。下面再说下我在解决问题遇到的几种特殊的情况。

第一种情况:只要生成xxx.so文件与原来自带的动态库文件在同一个目录下面(不在同一个目录下面的软链接不起作用,具体见第三种情况),那么除了上面说到的拷贝方法生成.so文件,也可以通过创建软链接(ln -s 源文件 目标文件), 也可以达到目标,生成完以后通过"ls -al | grep libboost"查看生成软链接。

第二种情况:如果仅仅是进行了复制或者创建软链接到当前目录,而没有修改"/etc/ld.so.conf"文件,则可能会碰到下面的错误。

第三种情况:如果不在同一个目录的话,比如动态库文件在"/usr/lib"下面,想要生成的"xxx.so"文件存放在"/usr/local/lib"下面的情况。

注意一:不能用软链接的方法,只能通过拷贝的办法来实现。创建的软链接与本来的动态库文件要是不在一个目录,编译依然会报错,即使编译的时候通过“-L”指定动态库所在的文件夹也不会起作用。这里软链接虽然没用,但是当要创建的软链接与源文件不在同一目录时,创建软链接一定要用绝对路径,使用相对路径名会造成不必要的错误。

注意二:通过拷贝的办法来实现第三种情况,用拷贝“cp"命令将动态库文件以".so"结尾拷贝到"/usr/local/lib"下面。

然后修改相应的"/etc/ld.so.conf"文件,在终端输入"ldconfig"使配置生效。然后编译,编译通过以后,会发现系统会自动在“/usr/local/lib"下面创建关于".so"文件的软链接(原因不详)。编译通过,会在”/usr/local/lib“文件夹中自动生成了软链接,链接到".so"文件。

下面就来运行下生成的a.out吧。

# ./a.out

Debian Linux系统安装配置 MongoDB数据库过程
分享到:
Python分布式文件系统 MongoDB GridFS 介...
Python分布式文件系统 MongoDB GridFS 介绍mongodb GridFS 性能 性能, 网评还不错. 不过在生产环境中,国外有用于存储视频流的. GridFS的一个优点是可以存储上百万的文件而无需担心扩容性. 通过同步复制,可以解决分布式文件的备份问题. 通过ARP-ping可以实现一个双机热备切换,类mysql的mysql master master replic 使用Nginx...
Ubuntu系统如何安装MongoDB数据库
Ubuntu系统如何安装MongoDB数据库UBuntu上安装MongoDB server 获取最新版本 wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.0.2.tgz 解压缩即可执行 tar zxvf mongodb-linux-x86_64-2.0.2.tgz cd /usr/mongodb-linux-x86_64-2.0.2/bin 但是在运行前,需要创建mongodb需要的存放数据和日志的目录:...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……