Nginx-gridfs是一个 Nginx 的扩展模块,用于支持直接访问 MongoDB 的 GridFS 文件系统上的文件并提供 HTTP 访问,可理解为就是MongoDB的客户端。

在进行下面的操作前,需要提前安装好mongodb

Nginx-gridfs和Nginx配置

1、安装依赖库、工具
# yum -y install pcre-devel openssl-devel zlib-devel
# yum -y install gcc gcc-c++
2、下载nginx-gridfs源码
# git clone https://github.com/mdirolf/nginx-gridfs.git
# cd nginx-gridfs
# git checkout v0.8
# git submodule init
# git submodule update

git submodule update时,可能会出现问题:

Cloning into 'mongo-c-driver'...
fatal: unable to connect to github.com:
github.com[0: 13.229.188.59]: errno=Connection timed outClone of 'git://github.com/mongodb/mongo-c-driver.git' into submodule path 'mongo-c-driver' failed

原因:
需要用https才能读到数据
解决方法:输入命令
git config --global url.“https://”.insteadOf git://

3、下载nginx源码,编译安装
# wget http://nginx.org/download/nginx-1.4.7.tar.gz
# tar zxvf nginx-1.4.7.tar.gz
# cd nginx-1.4.7
# ./configure --with-openssl=/usr/include/openssl --add-module=../nginx-gridfs/
# make -j8 && make install -j8

make -j8 && make install -j8时,出现问题:

cc1: all warnings being treated as errors
make[1]: *** [objs/addon/nginx-gridfs/ngx_http_gridfs_module.o] Error 1
make[1]: Leaving directory `/nginx-1.4.7'
make: *** [build] Error 2

解决方法:
在objs/Makefile中将 -Werror 删除,对于warnings忽略

然后再执行make && make install 安装

问题搞定;

4、修改/usr/local/nginx/conf/nginx.conf配置文件。
location /pics/ {gridfs picsfield=filenametype=string;mongo 127.0.0.1:27017;
}

上例中数据库是pics,通过文件名filename来访问文件,filename的类型是string

  • root_collection= collection的前缀,默认值: fs
  • field= 访问文件的字段,只支持id和文件名
  • type= 文件类型,可以为string,int,object等,default: objectid
  • user= 需要认证时用户名
  • pass= 需要认证时用密码
    详情参考:
    https://github.com/mdirolf/nginx-gridfs

启动nginx服务

# /usr/local/nginx/sbin/nginx
5、测试

上传一个图片001.jpg到pics数据库中
打开:http://localhost/pics/001.jpg

如果成功,则可以看到显示图片了。

Nginx+Mongodb 文件存储方案相关推荐

  1. 系统中的文件存储方案

    项目中经常要用到文件存储 方案1: 文件传给后端,后端存到本地,当静态资源 方案2: 文件传给后端,后端上传到文件服务器(如minio) 方案3: 前端从后端获取到文件服务器的账户和密码,然后前端直接 ...

  2. Pure公司发布机架规模FlashBlade对象与文件存储方案

    FlashBlade为Pure Storage公司的机架规模闪存系统,其采用多种协议以访问非结构化数据,同时也是市场上第一套基于对象的全闪存非结构化数据存储系统. 不过其机架规模与EMC的DSSD机架 ...

  3. 架构方案(16) 常见分布式文件存储介绍、选型比较、以及架构设计

    数据正成为世界上最有价值的资源,分布式文件存储是应对数据爆炸的最好解决方案,那就会涉及到分布式文件存储方案.选型.架构设计等. 分布式文件存储的来源 在这个数据爆炸的时代,产生的数据量不断地在攀升,从 ...

  4. 【重识云原生】第三章云存储3.5节——商用分布式云存储方案

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第二章计算第2节--主流虚拟化技术之VMare ESXi 第二章计算第3节--主流虚拟 ...

  5. 常见分布式文件存储介绍、选型比较、架构设计

    数据正成为世界上最有价值的资源,分布式文件存储是应对数据爆炸的最好解决方案,那就会涉及到分布式文件存储方案.选型.架构设计等. 分布式文件存储的来源 在这个数据爆炸的时代,产生的数据量不断地在攀升,从 ...

  6. BigData之MongoDB:MongoDB基于分布式文件存储数据库的简介、下载、案例应用之详细攻略

    BigData之MongoDB:MongoDB基于分布式文件存储数据库的简介.下载.案例应用之详细攻略 目录 MongoDB的简介 1.MongoDB的主要功能特性 2.对MongoDB进行增删改查( ...

  7. MongoDB 一个基于分布式文件存储的数据库

    简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. 特点 它的特点是高性能.易部署.易使用,存储数据非常方便.主要功能特性有: ...

  8. php sqlite存入文件夹,PHP_小文件php+SQLite存储方案,我们草根站长购买的虚拟主机 - phpStudy...

    小文件php+SQLite存储方案 我们草根站长购买的虚拟主机往往都有文件数量限制,大量小文件占用大量资源,落伍精华区也有兄弟推荐豆瓣的解决方法,但是要有主机权限.只能另装思路,采用php+SQLit ...

  9. sock 文件方式控制宿主机_基于嵌入式Linux系统实现YAFFS2文件系统存储方案的设计...

    随着嵌入式技术的不断发展,嵌入式系统的应用越来越广泛,人们对于嵌入式系统功能的要求也越来越高,相应地其大容量数据存储和管理变得越来越重要.相对硬盘而言,FLASH等非易失性存储器具有体积小.功耗低.成 ...

最新文章

  1. Design Pattern - Command (C#)
  2. Android 系统镜像: boot.img kernel.img ramdisk.img system.img userdata.img cache.img recovery.img
  3. Python基础之循环语句
  4. Windows Phone 实用开发技巧(3):输入框自动聚焦并打开SIP
  5. sqlsugar 批量删除guid类型主键_SAP使用MASS批量修改主数据
  6. ICallbackEventHandler不支持二次回调的问题
  7. 在mac上用文本编辑器写python_Mac开源文本编辑器CotEditor
  8. Springboot 关于日期时间格式化处理方式总结
  9. Latex的空格 转载
  10. 【C#】eventlog类的使用
  11. Apache Tomcat安装配置
  12. proteus 的使用
  13. 【Proteus仿真】TLC5615输出1024点正弦波(振幅可调)
  14. 和平精英小程序服务器开小差,1个BUG存在了4年 光子通过小提示说出了无法修复的原因...
  15. excel文件被写保护怎么解除_如何去掉Excel表格中的密码保护?
  16. 计算机d盘变为raw,d盘文件系统raw 硬盘变成raw格式怎么办
  17. php八字喜用神实现博客,八字中实例教你取用神
  18. java狗叫_java学习(8) | 学步园
  19. opencv实现车牌识别之字符分割
  20. 《DSP using MATLAB》示例9.2

热门文章

  1. 使用maven根据JSON文件自动生成Java POJO类(Java Bean)源文件
  2. windows server 2008 - 隐藏磁盘分区 (2)
  3. web项目在iis配置好后不能正确访问问题集锦,以及IIS常规设置
  4. 一个拼凑sql,输出变量的 存储过程
  5. 【数据库系统设计】数据库安全性
  6. 【网络安全工程师面试合集】—黑客常用的端口及攻击方法汇总
  7. samba服务器的搭建【在windows查看linux的共享文件】
  8. 【必备干货】1000字讲清3大财务数据表
  9. 帆软报表重要Activator之DesignerInitActivator之三NorthRegionContainerPane 主要是设计器菜单栏的部分
  10. android 状态栏一体化 fragment,单Activity多Fragment动态修改状态栏颜色功能