GridFS大文件的添加、获取、查看、删除
GridFS是一种在MongoDB中存储大二进制文件的机制,使用GridFS的原因有以下几种:
存储巨大的文件,比如视频、高清图片等。
利用GridFS可以简化需求。
GridFS会直接利用已经建立的复制或分片机制,故障恢复和扩展都很容易
GridFS可以避免用户上传内容的文件系统出现问题。
GridFS不产生磁盘碎片。
GridFS使用两个表来存储数据:
fiiles包含元数据对象(如文件的名称、上传的时间)
chunks包含其他一些相关信息的二进制块
为了使度个GridF命名为一个单一的数据库,文件和块都有一个前缀,默认情况下,前缀是fs。
所以任何默认的GridFS存储将包括命名空间fs.files和fs.chunks。(图片可以命名为ps.files和ps.chunks,视频可以命名为vs.files和vs.chunks)。
各种第三方语言可以更改其前缀。
本文是oschina的happyBKs的文章,请自己标明出处:http://my.oschina.net/u/1156339/blog/388156
使用GridFS mongofiles
mingofiles是从命令行操作GridFS的一种工具
三个命令:put(存储) get(取得) list(列表)
例如:我们将“testfile”这个文件存储到库中,具体做法是 ./mongofiles put testfile
首先,我们尝试压缩归档一个文件。
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles list
- [sudo] password for neil:
- connected to: 127.0.0.1
- [neil@neilhost ~]$ tar zcf mongodbBook.tar.gz Downloads/MongoDB权威指南.pdf
- [neil@neilhost ~]$ ll mongodbBook.tar.gz
- -rw-rw-r--. 1 neil neil 203 3月 16 19:10 mongodbBook.tar.gz
下面我们将这个归档文件存储到mongoDB中。默认存放到test数据库中。
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles put ./mongodbBook.tar.gz
- connected to: 127.0.0.1
- added file: { _id: ObjectId('5506bc01581b37b38b49fecd'), filename: "./mongodbBook.tar.gz", chunkSize: 261120, uploadDate: new Date(1426504705885), md5: "85c0c93f51ebe9c609ffe4f9da71c63e", length: 203 }
- done!
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles list
- connected to: 127.0.0.1
- ./mongodbBook.tar.gz 203
- [neil@neilhost ~]$
之后,我们进入mongodb客户端查看test数据库,发现里面多了两个集合,一个是fs.files,查看之后发现里面记录着上传文件的以下像信息:文件名称、上传时间、md5码、文件长度、大小等。
fs.chunks查看显示二进制信息。
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongo
- [sudo] password for neil:
- MongoDB shell version: 2.6.8
- connecting to: test
- > show tables
- fs.chunks
- fs.files
- system.indexes
- >
- >
- > db.fs.files.find()
- { "_id" : ObjectId("5506bc01581b37b38b49fecd"), "filename" : "./mongodbBook.tar.gz", "chunkSize" : 261120, "uploadDate" : ISODate("2015-03-16T11:18:25.885Z"), "md5" : "85c0c93f51ebe9c609ffe4f9da71c63e", "length" : 203 }
- > db.fs.chunks.find()
- { "_id" : ObjectId("5506bc011b359e376ad0011e"), "files_id" : ObjectId("5506bc01581b37b38b49fecd"), "n" : 0, "data" : BinData(0,"H4sIADm6BlUAA+3OvwsBcRjH8a+uZOE/kNuYuOO+btetMvkD1CHFnfzISgYDZqWU0d9g4w+x3W1mq7uUkmKgpN6v4Xnq+Tz1PJY7ctpuze7nyq7TdK2Sv5l6u4m/mHnLVbZrN8TntEDR0MKum/Kh30gp9LzUdFkIiwhSwzCFqn3h9lvD/qDWU1Xh1FvtV3vv8j+VmsdEfB+tCuV8iMSDwXF7qXQS5va+MTaV9SmZFpmf/QgAAAAAAAAAAAAAAAAAeHYFpzavuwAoAAA=") }
- >
这个文件不大,所以二进制信息很短。
- [neil@neilhost ~]$ du mongodbBook.tar.gz
- 4 mongodbBook.tar.gz
接下来,我尝试将mongodbBook.tar.gz的原文件删除,然后从mongodb中获取恢复。
这里用到的是mongofiles get命令。这里注意的是
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles list
- connected to: 127.0.0.1
- ./mongodbBook.tar.gz 203
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles get mongodbBook.tar.gz
- connected to: 127.0.0.1
- ERROR: file not found
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles get ./mongodbBook.tar.gz
- connected to: 127.0.0.1
- done write to: ./mongodbBook.tar.gz
- [neil@neilhost ~]$ ll
- 总用量 44
- drwxr-xr-x. 2 neil neil 4096 2月 13 18:36 Desktop
- drwxr-xr-x. 3 neil neil 4096 2月 13 21:35 Documents
- drwxr-xr-x. 5 neil neil 4096 3月 15 21:56 Downloads
- -rw-r--r--. 1 root root 203 3月 17 18:27 mongodbBook.tar.gz
- drwxr-xr-x. 2 neil neil 4096 2月 13 18:36 Music
- drwxr-xr-x. 3 neil neil 4096 3月 15 22:50 Pictures
这里需要注意的是,后面get的文件名称需要指定路径,这里要加上./,否则会显示文件不存在。
注意,这个./指的不是linux当前的路径,而是在Mongodb的文件存储中的路径。
之后,有put有get必有delete。
接下来看看如何删除MongoDB中的大文件.
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles list
- [sudo] password for neil:
- connected to: 127.0.0.1
- ./mongodbBook.tar.gz 203
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles delete ./mongodbBook.tar.gz
- connected to: 127.0.0.1
- done!
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongofiles list
- connected to: 127.0.0.1
- [neil@neilhost ~]$ sudo /usr/local/mongodb/bin/mongo
- MongoDB shell version: 2.6.8
- connecting to: test
- > db
- test
- > show collections
- fs.chunks
- fs.files
- system.indexes
- > db.fs.files.find()
- >
- > db.fs.chunks.find()
- >
删除之后可以看到fs.files中的元数据和fs.chunk中的二进制数据都没有了。
--------------------- 本文来自 Ghost丶 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/linux_hacher/article/details/79663911?utm_source=copy
GridFS大文件的添加、获取、查看、删除的更多相关文章
- Visual Studio 2015 自动生成 的大文件xxx.vc.db的删除问题
用vs2015创建Visual C++项目,编写生成后,每次都会生成一个project_name.VC.db文件,而且会随着你工程修改运行变的越来越大. project_name.VC.db是sqli ...
- 删除Git记录里的大文件
删除Git记录里的大文件 仓库自身的增长 大多数版本控制系统存储的是一组初始文件,以及每个文件随着时间的演进而逐步积累起来的差异:而 Git 则会把文件的每一个差异化版本都记录在案.这意味着,即使你只 ...
- 记一次删除Git记录中的大文件的过程
app/test/target/ #查看大文件 git rev-list --objects --all | grep "$(git verify-pack -v .git/objects/ ...
- 利用Linux的硬连接删除MySQL大文件
利用Linux的硬连接删除MySQL大文件 http://blog.csdn.net/wxliu1989/article/details/22895201 原理:硬链接基础当多个文件共同指向同一ino ...
- Nginx 做代理服务器时浏览器加载大文件失败 ERR_CONTENT_LENGTH_MISMATCH 的解决方案
此文章仅作为本人的笔记,文章转载自 http://blog.csdn.net/defonds/article/details/46042809 Nginx 做反向代理,后端是 tomcat,chro ...
- Linux大文件已删除,但df查看已使用的空间并未减少解决
在我的生活当中遇到磁盘快满了,这时候准备去删除一些大文件 于是我使用ncdu 查看了一下当前系统占用资源比较多的是那些文件,结果一看是elasticsearch的日志文件,好吧,竟然找到源头了,那就把 ...
- 牛客网Java刷题知识点之File对象常用功能:获取文件名称、获取文件路径、获取文件大小、获取文件修改时间、创建与删除、判断、重命名、查看系统根目录、容量获取、获取某个目录下内容、过滤器
不多说,直接上干货! 获取文件名称.获取文件路径.获取文件大小.获取文件修改时间 FileMethodDemo.java package zhouls.bigdata.DataFeatureSelec ...
- 如何安放你的大文件,MongoDB GridFS可以帮助你
1 简介 众所周知(你不知也当你知),MongoDB是以文档(Document)组织数据的.除了常用于存储Json数据,它也是可以存储普通文件的.我们可以把一些文件以BSOON的格式存入MongoDB ...
- [原创]java WEB学习笔记66:Struts2 学习之路--Struts的CRUD操作( 查看 / 删除/ 添加) 使用 paramsPrepareParamsStack 重构代码 ,PrepareInterceptor拦截器,paramsPrepareParamsStack 拦截器栈
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
随机推荐
- 【编码】封装RedisPubSub工具
基本介绍 核心原理:利用Redis的List列表实现,发布事件对应rpush,订阅事件对应lpop 问题一:Redis不是自带Pub/Sub吗? redis自带的pub/sub有两个问题: 1.如果发 ...
- Unable to locate Attribute with the the given name [] on this ManagedType
最近在写Springboot+hibernate的项目,遇到这个问题 好坑,查了半天没发现我哪里配置错了,后来发现实体类声明字段大小写敏感,把声明字段改成小写就行了
- Servlet(生命周期)
<?xml version="1.0" encoding="UTF-8"?> <web-app version="3.0" ...
- [反汇编练习] 160个CrackMe之023
[反汇编练习] 160个CrackMe之023. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...
- 【转载】一张“神图”看懂单机/集群/热备/磁盘阵列(RAID)
单机部署(stand-alone):只有一个饮水机提供服务,服务只部署一份 集群部署(cluster):有多个饮水机同时提供服务,服务冗余部署,每个冗余的服务都对外提供服务,一个服务挂掉时依然可用 热 ...
- Java字符串String 集合的迭代器
Java字符串String 我们知道Java的字符窜是Immutable(不可变)的,一旦创建就不能更改其内容了:平常我们对字符串的操作是最多的,其实对字符串的操作,返回的字符串都是新建的字符串对象, ...
- Erlang进程堆垃圾回收机制
原文:Erlang进程堆垃圾回收机制 作者:http://blog.csdn.net/mycwq 每一个Erlang进程创建之后都会有自己的PCB,栈,私有堆.erlang不知道他创建的进程会用到哪种 ...
- 浅谈xss原理
近日,论坛上面XSS满天飞,各处都能够见到XSS的痕迹,前段时间论坛上面也出现了XSS的迹象.然后我等小菜不是太懂啊,怎么办?没办法仅仅有求助度娘跟谷歌这对情侣了. 能够说小菜也算懂了一些.不敢藏私, ...
- Python基础——数据类型、流程控制、常用函数
Python tutorial :Python网站上的对 Python 语言和系统的基本概念和功能进行的非正式的介绍. 在学习Python之前,我们需要学会在各个平台配置Python的运行环境,下文中 ...
- Spring Boot与Micronaut性能比较
文章转载出处:微信公众号——锅外的大佬 链接:https://mp.weixin.qq.com/s/MdBByJ0ju-rROKg7jsWygA 今天我们将比较两个在JVM上构建微服务的框架:Spri ...