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 还能查看端口静态状态
[root@zjhl1 opt]# ps -ef | grep mongo root 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 --logappend root 19027 10593 0 17:21 pts/1 00:00:00 grep mongo [root@zjhl1 opt]# [root@zjhl1 opt]# netstat -ant | grep 27017 tcp 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名称 地址:端口
#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 。
try { Mongo mongo = new Mongo("192.168.100.52", 27017);// 创建连接 DB db = mongo.getDB("pics"); // 选择数据库 byte[] files = createImage(800, 600, "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实现简单文件上传、下载、搜索、删除。 开发环境:VS2012 mongodb驱动:官方Driver 上传控件:jquery uploadify 疑问:sort()方法可能有点问题 PS:有问题可以留言,欢迎交流~
基于node.js、vue、mongodb等技术构建的web系统,界面美观,功能齐全,适合用作毕业设计、课程设计作业等,项目均经过测试,可快速部署运行! 基于node.js、vue、mongodb等技术构建的web系统,界面美观,功能齐全,...
gridfs2s3 - 将 MongoDB GridFS 文件迁移到 AWS S3 的工具 这是一个简单的工具,它将抓取您指向的 GridFS 中的所有文件,并将它们粘贴到 S3 中 安装 go install github.com/Bowbaq/gridfs2s3 用法 gridfs2s3 -h flag...
主要介绍了PHP MongoDB GridFS 存储文件的方法详解的相关资料,需要的朋友可以参考下
java+mongDB做文件服务器,用于文件存储,写了个简单文件上传下载删除DEMO,用eclipse import项目即可。
Mongodb的gridfs的C#的例子
网站大量图片存储需要用到Mongodb,本代码中以图片上传、图片更新、图片删除为例子,展示了以GridFS方式对文件进行存取。
MongoDB GridFS.pdf 学习资料 复习资料 教学资源
Vue+axios+Spring Boot+mongoDB 基于Mongo图片存储和基于GridFS的文件存储.zip
但是,由于它将文件存储在ASCII字符串块中,因此毫无疑问会降低性能。 我正在尝试从GridFS读取3种不同的部署(不同的MongoDB驱动程序)。 并将结果与经典的Nginx配置进行比较。贡献者( ) ( )构型1,Nginx ...
本篇文章是对PHP操作MongoDB GridFS存储文件进行了详细的分析介绍,需要的朋友参考下
Java 操作Mongodb中存储的文件的实例
NULL 博文链接:https://shift-alt-ctrl.iteye.com/blog/2195646
MongoDB.GridFS.dll c#类库...............................................
MongoDB构建分布式文件存储的数据库MongoDB构建分布式文件存储的
本文实例讲述了Python保存MongoDB上的文件到本地的方法。分享给大家供大家参考,具体如下: MongoDB上的文档通过GridFS来操作,Python也可以通过pymongo连接MongoDB数据库,使用pymongo模块的gridfs方法操作文档。...
文件上传到MongoDBGFS和Express 使用 Express 和 Multer 编写的 MongoDB GridFS 文件服务器示例依赖关系此示例上传文件并将它们存储在 MongoDB 的 GridFS 中。 要运行此示例,您需要在系统上安装 MongoDB。 在 OSX ...