一、前言
在gitee和github里面基本上找不到一款好用、功能完善、且开放源码的网盘系统,有一些可以免费试用但是只提供安装包,于是在利用业务时间开发了一套轻量级且易于上手的网盘系统,主要基于目前主流的前后端分离和微服务架构模式开发,里面涉及很多的解决方案,适合没有项目经验的同学学习。
网盘系统的核心目的有两个:
提供客户端给业务系统集成,统一管理业务系统的文件;
提供在线协调办公、管理个人文件的功能。系统会陆续更新和完善一些功能。
二、部署架构说明
三、技术栈说明
前端技术
①vue.js+ElementUI 作为基础技术框架
②WebUploader.js做切块上传框架
后端技术
①Maven+SpringBoot+SpringDataJPA作为基础架构
②Dubbo+Zookeeper作为服务治理架构
③Nacos作为配置中心
④Redis做分布式缓存、过期监听
⑤Zookeeper做分布式锁
⑥WebSocket+Netty做消息推送
⑦Solr做全文检索引擎
⑧FastDFS做分布式文件系统
⑨基于Redis+token+自定义注解实现接口幂等性
四、功能说明
1、网盘系统
①上传功能:主要是针对大文件的切块上传、秒传、文件夹上传
②下载功能:主要是大文