您的当前位置:首页mongodb gridfs基本使用

mongodb gridfs基本使用

2023-11-09 来源:哗拓教育

 Mongodb GridFS图片文件存储解决方案

    之前解决方案是接收图片数据后,将图片直接存储到盘阵,然后通过Apache做服务器,将图片信息存储到数据库,并且存储一个Apache的访问路径。

    目前需要后台服务存储图片,将图片存储到MongoDB集群中,然后通过Nginx中的nginx-gridfs模块进行访问,在浏览器中通过url访问,效果与Apache访问本地文件一样。

     本方案的内容比较基础,以后会有深入了解和优化,敬请期待!

一、安装MongoDB

    (1)安装MongoDB

      进入计划安装目录:cd  /usr/local/ 

     下载mongodb-linux-x86_64-2.6.1.tgz  https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.6.1.tgz

      解压:tar -zxf mongodb-linux-x86_64-2.6.1.tgz

      改名:mv mongodb-linux-x86_64-2.6.1 mongodb2.6.1

      创建数据目录和日志目录: mkdir -p mongodb2.6.1/mongodb_data/mongodb_db

                                                 mkdir -p mongodb2.6.1/mongodb_data/mongodb_logs

     启动MongoDB: 进入MongoDB bin目录执行以下命令:

      cd /usr/local/mongodb2.6.1/bin

      ./mongod --dbpath=/usr/local/mongodb2.6.1/mongodb_data/mongodb_db/ --logpath=/usr/local/mongodb2.6.1/mongodb_data/mongodb_log/mongodb.log --logappend &

      检查启动状态:

      ps -ef | grep mongo 看到刚才启动命令就说明在运行了

      通过 netstat -ant | grep 27017 还能查看端口静态状态

?
12345678910[root@zjhl1 opt]# ps -ef | grep mongoroot     16350 10593  1 15:40 pts/1    00:01:11 ./mongod --dbpath=/opt/mongodb2.6.1/mongodb_data/mongodb_db/ --logpath=/opt/mongodb2.6.1/mongodb_data/mongodb_logs/mongodb.log --logappendroot     19027 10593  0 17:21 pts/1    00:00:00 grep mongo[root@zjhl1 opt]# [root@zjhl1 opt]# netstat -ant | grep 27017tcp        0      0 0.0.0.0:27017               0.0.0.0:*                   LISTEN      tcp        0      0 127.0.0.1:27017             127.0.0.1:47686             ESTABLISHED tcp        0      0 127.0.0.1:47686             127.0.0.1:27017             ESTABLISHED tcp        0      0 192.168.1.111:27017         192.168.1.100:53462         ESTABLISHED [root@zjhl1 opt]#

(2)安装MongoVUE客户端

      MongoVUE是类似oracle中PL/SQL Developer 或者MySql中SQLyog的图形化客户端。

      目前是收费的,下载后Installer.msi后直接安装就行。至于授权问题自己百度解决。

      此工具的功能很多,这里不展开讲,有需要的自己百度。

    

      

 

二、安装Nginx

    (1)下载nginx-gridfs插件

      网上有传出使用git安装此插件的,这个比较麻烦,我在文章的附件中留了下载包。本人测试可用。

      下载后还要下载mongo的c语言驱动包,这个也可以在附件中下载。

      下载完成后进行解压:tar -zxf nginx-gridfs.tar.gz

                                         tar -zxf mongo-c-driver-0.94.2.tar.gz

       解压完成后将驱动包内容全部拷贝到nginx-gridfs目录下的mongo-c-driver目录中:

       mv mongo-c-driver-0.94.2/*  nginx-gridfs/mongo-c-driver/   

       如果有提示已经存在src目录,没有关系,忽略。然后就是下载Nginx,编译安装的过程了。

    (6)下载Nginx1.0.1

     Nginx版本太高对支持nginx-gridfs模块不是很成功,我是使用的Nginx1.7弄了一天都出不来图片。换成1.0.1就好了。对c不是很熟悉就没有深究。有那位大拿知道可以告诉我。

      wget http://nginx.org/download/nginx-1.0.1.zip

      解压:unzip nginx-1.0.1.zip 

      配置编译时设置:./configure --prefix=/usr/local/nginx --with-openssl=/usr/include/openssl --with-http_stub_status_module --add-module=/opt/nginx-gridfs

      编译: make

      安装:make install

      配置mogon-gridfs地址:

      在vim /usr/local/nginx/conf/nginx.conf配置文件中,增加下面的内容:

        location /pics/ {                gridfs pics                     field=filename                type=string;                mongo 127.0.0.1:27017;        }

      

     gridfs:nginx识别插件的名字

     pics:数据库名称

     [root_collection]: 选择collection,如root_collection=blog, mongod就会去找blog.files与blog.chunks两个块,默认是fs

     [field]:查询字段,保证mongdb里有这个字段名,支持_id, filename, 可省略, 默认是_id

     [type]:解释field的数据类型,支持objectid, int, string, 可省略, 默认是int

     [user]:用户名, 可省略

     [pass]:密码, 可省略    

     mongo:mongodb url mongo名称 地址:端口

?
12345678910111213        #access_log  logs/host.access.log  main;        location / {            root   html;            index  index.html index.htm;        }        location /pics/ {                gridfs pics                field=filename                type=string;                mongo 127.0.0.1:27017;        }        #error_page  404              /404.html;        # redirect server error pages to the static page /50x.html

 启动:/usr/local/nginx/sbin/nginx &

      查看日志:tail -f /usr/local/nginx/logs/error.log

      检查: 在浏览器输入: http://192.168.1.111/

      当你看到下面的字母就说明nginx启动成功了。

     Welcome to nginx!

 

三、测试开发

      测试例子使用java开发,代码在附件中

    (1)图片写入

     全部的例子在附件中,GridFSTest.rar,例子还需要mongodb的驱动jar包mongo-java-driver-2.9.3.jar 。

?
12345678                try {   Mongo mongo = new Mongo("192.168.100.52"27017);// 创建连接   DB db = mongo.getDB("pics"); // 选择数据库   byte[] files = createImage(800600"800 X 600"); // 创建图片   save(files, "test3.jpg", db); // 存储图片  catch (Exception e) {   e.printStackTrace();  }

 

(2)文件获取

        通过代码获取图片就不写了。只写如何在程序中传递文件路径,然后在前端展示。

       存储图片信息时,可以加上ip地址:http://192.168.100.52/pics/test3.jpg ,然后前端应用通过给定的URL地址就可以获取图片内容了。

       在浏览器中输入地址可以获得相同的效果。

mongodb gridfs基本使用

标签:

小编还为您整理了以下内容,可能对您也有帮助:

mongodb gridfs性能

1) 普通插入性能 (插入的数据每条大约在1KB左右)

2) 批量插入性能 (使用的是官方C#客户端的InsertBatch),这个测的是批量插入性能能有多少提高


3) 安全插入功能 (确保插入成功,使用的是SafeMode.True开关),这个测的是安全插入性能会差多少。

4) 查询一个索引后的数字列,返回10条记录(也就是10KB)的性能,这个测的是索引查询的性能。

mongodb gridfs性能

1) 普通插入性能 (插入的数据每条大约在1KB左右)

2) 批量插入性能 (使用的是官方C#客户端的InsertBatch),这个测的是批量插入性能能有多少提高


3) 安全插入功能 (确保插入成功,使用的是SafeMode.True开关),这个测的是安全插入性能会差多少。

4) 查询一个索引后的数字列,返回10条记录(也就是10KB)的性能,这个测的是索引查询的性能。

mongoDB1--什么是mongoDBmongodb

1.mongodb与其它nosql数据库的区别

我们之前应该接触过redis或者memcached,他们属于key-value数据库,他们运用哈希算法关联起来,能够达到快速的查询目的。

而mongodb是一种“文档数据库”,存储类型是以文档为主,该文档类型为(Bson,其实就是json的二进制对象)。

特点:mongodb的内部引擎是使用javascript解释器实现的,把文档存储成bson结构,在查询时,转换为js对象,并可以通过大家熟悉的js语法进行操作。

原理:mongodb在电脑磁盘文件系统之上,又包装了自己的一套文件系统---gridfs,里面存储的是一个一个的json二进制对象,也就是Bson。

我们如果想对Bson对象进行“增删改查”,我们就要使用js来操作,我们直接使用js来操作,然后mongodb内置的js引擎将我们的js解析成Bson对象的相关操作,然后执行增删改查。

2.mongodb和传统关系型数据库(Mysql/SqlServer/Oracle等)的区别

传统关系型数据库:结构化数据,定好了表结构之后,每一行的内容必是符合表结构的,就是说,列的个数,类型都一样。

mongodb的文档型数据库:以文档为单位,不用事先声明结构。我们创建json格式的数据,直接存储到mongodb的文档中。

与传统关系型数据库不同的是,我们可以创建不同结构(json对象都可以有自己独特的属性和值)的对象,存在同一个表下面。

一般我们的网站都有评能,有一些评论的下面还有回复,回复可以还有回复,也就是我们常说的楼中楼的效果:

在传统关系型数据库中,我们要有帖子表,然后有帖子的评论表,然后又有每个帖子的回复表,一些回复可能还会有打分,这样我们就要设计四张表,然后各自有主外键的关联,进行联合查询:

四张表查询起来效率不见得会很高。

而在mongodb中,就比较简单了。我们使用一个json格式就可以存储所有

的数据:

如此可见mongodb的一些优势。

下一篇我们将讲解mongdb的安装和基本的入门操作。

转载请注明出处:http://blog.csdn.net/acmman/article/details/53734215

mongoDB1--什么是mongoDB

标签:解释artcenteridtmem实现jsb分享增删改

显示全文