一个分布式在线网盘系统,包含一个Web IM
- 整体框架使用springboot,父子模块,前后端分离
- 使用zookeeper做服务注册与发现中心
- 使用shiro做登录认证
- 前端需配合netdisk-app使用
- 需要nginx做代理
- 需要redis
- 储蓄文件使用了分布式文件服务器FastDFS
- 数据库mysql
- 网盘文件树实现使用了mysql的储存过程
- 确保电脑上安装了mvn,而且加进了系统path中,运行
x-netdisk-web\src\main\resources\lib\install.cmd
,安装jave-1.0.2.jar
这个lib
- 处理web请求,可以部署多个,内部采用redis session集群共享方案
- 路由集中处理
- 订阅子模块
- 保存、获取用户聊天的路由
- 分发请求
- 可以部署多个(无状态)
- web im 的服务端,可以部署多个
- 使用quartz处理回收站,定时清理用户回收站
- 可以部署多个,quartz自带集群方案
- 公用mapper、entity、utils,被其他模块所依赖
- 整体框架参考 crossoverJie/cim
- shiro session 共享实现 alexxiyang/shiro-redis
- FastDFS springboot 解决方案 tobato/FastDFS_Client
- emoji 的 java 转换储存解决方案 vdurmont/emoji-java
- 增加将socket Ip注册到zookeeper,生产环境socket Ip需要公网
- 上传README.md文件以及数据库脚本
- 解决项目打包问题
- 加入quartz定时任务框架,处理回收站
- 史诗级更新,项目重构,file表拆分(总算把当年犯傻建的表改了...)
- 增加视频速率图
- 文件列表增加缩率图字段