MongoDB 学习笔记十二 GridFS、固定集合、自动增长
MongoDB GridFS
GridFS 用于存储和恢复哪些超过 16M(BSON文件限制)的文件(如:图片、音频、视频等)
GridFS 也是文件存储的一种方式,但是他是存储在 MongoDB 的集合中。
GirdFS 可以更好的存储大于 16 M 文件。
GridFS 会将大文件对象分割成多个小的 chunk(文件片段),一般为 256K/个,每个 chunk 将作为 MongoDB 的一个文档(document)被存储在 chunks 集合中。
GridFS 用两个集合来存储一个文件:fs.files 与 fs.chunks。
每个文件的实际内容被存在chunks(二进制数据)中,和文件有关的 meta 数据(filename、content_type,还有用户自定义的属性)将会被存在 files 集合中。以下是简单的 fs.files 集合文档:
{
"filename": "test.txt",
"chunkSize": NumberInt(261120),
"uploadDate": ISODate("2014-04-13T11:32:33.557Z"),
"md5": "7b762939321e146569b07f72c62cca4f",
"length": NumberInt(646)
}
以下是简单的 fs.chunks 集合文档:
{
"files_id": ObjectId("534a75d19f54bfec8a2fe44b"),
"n": NumberInt(0),
"data": "Mongo Binary Data"
}
GridFS 添加文件
现在我们使用 GridFS 的 put 命令来存储 mp3 文件。调用 MongoDB 安装目录下 bin 的 mongofiles.exe 工具。
打开命令提示符,进入到 MongoDB 的安装目录的 bin 目录中,找到 monfofiles.exe,并输入下面的代码:
>mongofiles.exe -d gridfs put song.mp3
GridFS 是存储文件的数据名称。如果不存在该数据库,MongoDB 会自动创建。 Song.mp3 是音频文件名。
使用以下命令来查看数据库中文件的文档:
>db.fs.files.find(