先简单的介绍一下文件系统和分布式文件系统
1、文件系统:是操作系统用来存取文件的,计算机通过文件系统存放数据。大部分均基于磁盘存储,典型的文件系统包括unix 的UFS,NTFS是window NT的文件存储系统。传统文件系统主要面临的问题就是磁盘容量不够时,需要扩容才可继续进行文件存储,如同咱电脑内存不够加块内存条。
2、分布式文件存储系统:同传统的纵向扩容不同,分布式文件存储系统通过存储文件节点,各节点通信形成文件系统网络,各节点通过网络进行数据传输。就像原来密集的数据信息通过一张节点织网,分布式文件系统负责对节点进行存储,数据文件可存储于其他存储系统中。
GridFS是分布式文件存储系统的典型代表。为mongoDB提供的数据存储解决方案,专门供大数据文件存储使用,主要用于存储视频、音频、图片,GridFS主要适用于文件数量较大的文件存储。
GridFS并非mongoDB的特有,不过是mongo选择使用这样一种文件存储解决方案进行存储自己的数据。用户上传的数据存储于mongo的集合中,【mongoDB的集合类似于关系数据库的表】
1、整体流程
2、代码演示
(1)首先新建maven项目
(2)在mongoDB官网下载mongo驱动jar包,
下载地址如下:https://docs.mongodb.org/ecosystem/drivers/
点击MongoDB Java Driver,将驱动坐标拷贝到maven pom文件中。
<dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver</artifactId> <version>3.2.0</version> </dependency> </dependencies>
(3)创建数据库连接、文件上传下载操作
public class GridFSDemo { public static void main(String[] args) throws FileNotFoundException { /* * 1、创建数据库连接 */ Mongo client= new Mongo("192.168.22.246",27017); //取得数据库对象 DB db=client.getDB("mongoTest"); String collectionName="mongoCollectionTest"; //创建数据库对象中GridFS集合 GridFS gridFS= new GridFS(db,collectionName); /* * 2、上传文件 */ //创建测试文件,mongo 默认存在该文件 File file=new File("F:/Java/疯狂JAVA讲义.pdf"); FileInputStream fileInputStream=new FileInputStream(file); //创建gridFS文件数据流 GridFSInputFile createFile=gridFS.createFile(fileInputStream); //设置文件属性 createFile.put("filename", "123Test.pdf"); createFile.put("contentType", "application/pdf"); createFile.save(); /* * 3、根据id查询上传文件 */ GridFSDBFile findOne= gridFS.findOne(new BasicDBObject("_id",createFile.getId())); System.out.print(findOne); /* * 4、查询所有文件列表 * DBCursor 数据库游标 */ DBCursor fileList=gridFS.getFileList(); while(fileList.hasNext()) { System.out.print(fileList.next()); } /* *5、 删除文件 */ gridFS.remove(new BasicDBObject("_id",createFile.getId())); client.close(); }
(4)程序效果展示
如图,在mongDB中新建名为【mongoTest】的数据库和【mongoCollectionTest】集合,将【123Test.pdf】上传到该集合中。
在ITOO项目中tool模块也封装了使用GridFS对mongoDB进行操作的底层方法,主要同【三】中的代码流程一致,通过创建数据库连接,建立数据库、集合,获取本地文件路径,创建文件输入流通过save方法将文件上传到数据库中。同样也有通过id查询、遍历查询所有文件列表、删除等方法。
/** * @MethodName : getMongo * @Description : 获取数据连接 * @return 返回mongon */ private Mongo getMongo(){ Mongo mongo=null; try { mongo = new Mongo("192.168.22.246",27017); } catch (Exception e) { e.printStackTrace(); } return mongo; } /** * @MethodName : uploadFile * @Description : 上传文件 * @param file :文件,File类型 * @param id :唯一标示文件,可根据id查询到文件.必须设置 * @param dbName :库名,每个系统使用一个库 * @param collectionName:集合名,如果传入的集合名库中没有,则会自动新建并保存 * @param map:放入你想要保存的属性,例如文件类型(“congtentType”".jpg"),字符串类型,区分大小写,如果属性没有的话会自动创建并保存 */ public void uploadFile(File file ,String id,String dbName,String collectionName,LinkedHashMap<String, Object> map){ //把mongoDB的数据库地址配置在外部。 try { Mongo mongo =getMongo(); //每个系统用一个库 DB db= mongo.getDB(dbName); System.out.println(db.toString()); //每个库中可以分子集 GridFS gridFS= new GridFS(db,collectionName); // 创建gridfsfile文件 GridFSFile gridFSFile = gridFS.createFile(file); //判断是否已经存在文件,如果存在则先删除 GridFSDBFile gridFSDBFile=getFileById(id, dbName, collectionName); if(gridFSDBFile!=null){ deleteFile(id, dbName, collectionName); } //将文件属性设置到 gridFSFile.put("_id", id); //循环设置的参数 if (map != null && map.size() > 0) { for (String key : map.keySet()) { gridFSFile.put(key, map.get(key)); } } //保存上传 gridFSFile.save(); } catch (Exception e) { e.printStackTrace(); } } /** * @MethodName : deleteFile * @Description : 删除文件 * @param id:文件对应的id * @param dbName:文件所在的库 * @param collectionName:文件所在的集合 */ public void deleteFile(String id,String dbName,String collectionName){ try { //获得mongoDB数据库连接。 Mongo mongo =getMongo(); //获得库 DB db= mongo.getDB(dbName); //获得子集 GridFS gridFS= new GridFS(db,collectionName); //删除文件 DBObject query=new BasicDBObject("_id", id); gridFS.remove(query); } catch (Exception e) { e.printStackTrace(); } } /** * 批量删除文件 * @MethodName : deleteFileByIds * @Description : TODO * @param ids * @param dbName * @param collectionName * */ public void deleteFileByIds(String[] ids,String dbName,String collectionName){ try { //获得mongoDB数据库连接。 Mongo mongo =getMongo(); //获得库 DB db= mongo.getDB(dbName); //获得子集 GridFS gridFS= new GridFS(db,collectionName); Map<String,String> map = new HashMap<String,String>(); for(int i=0;i<ids.length;i++){ //删除文件 DBObject query=new BasicDBObject("_id", ids[i]); gridFS.remove(query); } } catch (Exception e) { e.printStackTrace(); } } /** * @MethodName : getFileById * @Description : 根据Id获得文件 * @param id :文件Id * @param dbName: 数据库名 * @param collectionName:集合名 * @return GridFSDBFile */ public GridFSDBFile getFileById(String id,String dbName,String collectionName){ GridFSDBFile gridFSDBFile=null; try { //获得mongoDB数据库连接。 Mongo mongo =getMongo(); //获得库 DB db= mongo.getDB(dbName); //获得子集 GridFS gridFS= new GridFS(db,collectionName); //获得文件 DBObject query=new BasicDBObject("_id", id); gridFSDBFile=gridFS.findOne(query); } catch (Exception e) { e.printStackTrace(); } //返回数据 return gridFSDBFile; } /**查询集合中所有文件 * @MethodName : getAllFile * @Description : TODO * @param dbName * @param collectionName * * @return */ public List<GridFSDBFile> getAllFile(String dbName,String collectionName){ List<GridFSDBFile> gridFSDBFileList=null; try { //获得mongoDB数据库连接。 Mongo mongo =getMongo(); //获得库 DB db= mongo.getDB(dbName); //获得子集 GridFS gridFS= new GridFS(db,collectionName); //获得文件 DBObject query=new BasicDBObject();//空的构造 gridFSDBFileList = gridFS.find(query); } catch (Exception e) { e.printStackTrace(); } //返回数据 return gridFSDBFileList; }通过对GridFS结合java file类,实现了对各音频、视频、图片等数据在mongoDB上的存储,不可否认的是,作为NoSQL数据库mongoDB利用其自身独到之处被众多大型视频网站项目所青睐,GridFS便是其点睛之笔。期待进一步发现。