声明:该文章主要来自《MongoDB实战》一书内容,主要想通过该书学习MongoDB的相应知识,加深理解,故写在自己的博文当中,作为记录,在最后的章节中,会有一个自己集合MongoDB数据库应用的JavaEE的web应用。
1、简介
GridFS是一种将大型文件存储在MongoDB数据库中的文件规范,所有官方支持的驱动均实现了GridFS规范。
1.1、为什么要用GirdFS
由于MongoDB中BSON对象大小是有限制的,所有GridFS规范提供了一种透明的机制,可以将一个大文件分割成为多个较小的文档,这样的机制允许我们有效的保存大文件对象,特别是对于那些巨大的文件,比如视频、高清图片等。
1.2、如何实现海量存储
为实现这点,该规范制定了一个将文件分块的标准,每个文件都将在文件集合对象中保存一个元数据对象,一个或者多个chunk块对象可以被组合保存在一个chunk块集合中,大多数情况下,你无需了解此规范中细节。而可将注意力放在各个语言版本的驱动中有关GridFS API的部分或是如何使用mongofiles工具上。
1.3、语言支持
GridFS对Java、Perl、PHP、Python、Ruby等程序语言均支持,且提供了良好的API接口。
1.4、简单介绍
GridFS使用两个表来存储数据:
mongofiles是从命令行操作GridFS的一种工具,比如我们/usr/local/xuz/test.html文件存到库里面,具体用法如下:
[root@localhost bin]# ./mongofiles put /usr/local/xuz/test.html
connected to: 127.0.0.1
added file: { _id: ObjectId(‘54a8d33846d47e7bbe9a847a‘), filename: "/usr/local/xuz/test.html", chunkSize: 261120, uploadDate: new Date(1420350265089), md5: "aead353cb437d4d29d61f05bb548b191", length: 31 }
done!
下面我们查看一下库里有哪些GridFS文件,在mongofiles后加一个参数list即可。
[root@localhost bin]# ./mongofiles list
connected to: 127.0.0.1
/usr/local/xuz/test.html 31
接下来我们进库里看一下是否有新的东西
[root@localhost bin]# ./mongo
MongoDB shell version: 2.6.6
connecting to: test
> show collections
c1
c2
c3
c4
fs.chunks ----上文提到的fs.chunks
fs.files ----上文提到的fs.files
system.indexes
system.js
xuz
我们继续查看fs.files中的内容
> db.fs.files.find();
{ "_id" : ObjectId("54a8d33846d47e7bbe9a847a"), "filename" : "/usr/local/xuz/test.html", "chunkSize" : 261120, "uploadDate" : ISODate("2015-01-04T05:44:25.089Z"), "md5" : "aead353cb437d4d29d61f05bb548b191",
"length" : 31 }
字段说明:
原文地址:http://blog.csdn.net/xuzheng_java/article/details/42487167