MongoDB学习笔记之学习笔记之GridFS使用介绍使用介绍
主要介绍了MongoDB学习笔记之GridFS使用介绍,本文介绍了GridFS的作用、GridFS的一些使用方法、GridFS
实现原理及注意事项等,需要的朋友可以参考下
GridFS简介简介
GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
GridFS使用使用
MongoDB提供了一个命令行工具mongofiles可以来处理GridFS,
列出所有文件:
复制代码 代码如下:
mongofiles list
上传一个文件:
复制代码 代码如下:
mongofiles put xxx.txt
下载一个文件:
复制代码 代码如下:
mongofiles get xxx.txt
查找文件:
复制代码 代码如下:
//会查找所有文件名中包含“xxx”的文件
mongofiles search xxx
//会查找所有文件名以“xxx”为前缀的文件
mongofiles list xxx
参数说明:
–d 指定数据库 ,默认是fs,Mongofiles list –d testGridfs
-u –p 指定用户名,密码
-h 指定主机
-port 指定主机端口
-c 指定集合名,默认是fs
-t 指定文件的MIME类型,默认会忽略
GridFS实现原理实现原理
GridFS在数据库中,默认使用fs.chunks和fs.files来存储文件。
其中fs.files集合存放文件的信息,fs.chunks存放文件数据。
一个fs.files集合中的一条记录内容如下,即一个file的信息如下:
复制代码 代码如下:
{
"_id" : ObjectId("4f4608844f9b855c6c35e298"), //唯一id,可以是用户自定义的类型
"filename" : "CPU.txt", //文件名
"length" : 778, //文件长度
"chunkSize" : 262144, //chunk的大小
"uploadDate" : ISODate("2012-02-23T09:36:04.593Z"), //上传时间
"md5" : "e2c789b036cfb3b848ae39a24e795ca6", //文件的md5值
"contentType" : "text/plain" //文件的MIME类型
"meta" : null //文件的其它信息,默认是没有”meta”这个key,用户可以自己定义为任意BSON对象
}
对应的fs.chunks中的chunk如下:
复制代码 代码如下:
{