Files
xyFS/README.md

252 lines
8.9 KiB
Markdown
Raw Normal View History

2018-07-03 10:12:23 +08:00
# xyFS私有OSS文件存储服务
#### 项目介绍
2018-07-03 17:15:07 +08:00
一站式企业私有文件服务。针对软件开发时提供的文件存储系统,对文件上传、下载、分类、分组、审计、统计等操作进行业务剥离,支持企业内多项目提供统一的oss私有文件服务。
2018-07-03 10:21:57 +08:00
<br>
2018-07-03 17:15:07 +08:00
涵盖了保护企业隐私文件的私有存储也可接入公有云存储方案。开发初衷是应用于xyTalk企业IM即时通讯的离线文件存储、群文件、图片、短语音、短视频、企业文档库等应用。
2018-07-03 10:12:23 +08:00
<br>
xyTalk地址https://gitee.com/475660/xyTalk-pc
<br>
xyFS不仅仅是独立可用的文件系统还通过接口灵活集成以下服务
- 1.私有Xy.File OSS-FS文件服务 (自主开发,免费开源)
2018-07-05 17:04:28 +08:00
- 2.私有分布式文件MongoDB GridFS分布式文件系统
2018-07-03 10:12:23 +08:00
- 3.私有分布式文件FastDFS文件系统
2018-07-05 17:04:28 +08:00
- 4.私有分布式文件SeaweedFS
- 5.私有企业云存储Seafile网盘
- 6.私有BASE64转存关系数据库存储停用
- 7.公有云存储阿里OSS云存储
- 8.公有云存储:七牛云
- 9.公有云存储:腾讯文件云存储 CFS
<br>在第三方私有云领域我推荐SeaweedFS、GridFS。在公有云领域推荐阿里OSS和七牛云。
<br>SeaweedFS是一个高性能、自带Rest API的分布式文件系统可访问我的博客了解https://www.cnblogs.com/starcrm/p/9377851.html
2018-07-03 10:12:23 +08:00
2018-07-03 17:15:07 +08:00
#### 项目详细文档
http://xyfs.mydoc.io/
2018-07-25 11:07:12 +08:00
运行时访问地址:
<br>
http://localhost:9091/files/index/
2018-07-03 10:12:23 +08:00
#### 软件组成
- 1.xyFS 管理后端;
2018-07-03 10:20:20 +08:00
- 2.xyPortal Web前端中的“文档库”部分
2018-07-03 10:12:23 +08:00
- 3.xyFS HTTP API
- 4.xyFS JAVA Client
#### 采用技术
2018-07-05 17:04:28 +08:00
- 1.Spring Boot、MVC、AOP、Actuator、Swagger
2018-07-09 16:10:15 +08:00
- 2.Dbcp2、Druid数据库连接池2种模式可选
2018-07-03 17:15:07 +08:00
- 3.JPA/Hibernate
- 4.Ehcache
2018-07-24 16:54:30 +08:00
- 5.HTML、 Only Bootstrap4。只使用了单纯的Bootstrap4不再含其他任何前端UI框架。纯净、自然、轻量、极简、易维护。
2018-07-13 16:15:51 +08:00
- 6.Thymeleaf/Freemarker2种模板引擎可切换
2018-07-09 16:10:15 +08:00
- 7.MySQL、Oracle、SQLite3种数据库模式可选
2018-07-24 16:54:30 +08:00
- 8.其他Gradle、Tomcat、Nginx
2018-07-24 16:58:33 +08:00
#### 截图预览
首页界面:
<br>
2018-07-26 17:31:38 +08:00
<img alt="XyTalk FS" src="http://111.230.157.216/img/index.png" WIDTH="800" />
<br>
2018-07-24 16:58:33 +08:00
文件管理:
<br>
2018-07-26 17:31:38 +08:00
<img alt="XyTalk FS" src="http://111.230.157.216/img/files.png" WIDTH="800" />
<br>
2018-07-24 16:58:33 +08:00
API管理:
<br>
2018-07-26 17:31:38 +08:00
<img alt="XyTalk FS" src="http://111.230.157.216/img/api.png" WIDTH="800"/>
<br>
2018-07-24 16:58:33 +08:00
测试上传:
<br>
2018-07-26 17:31:38 +08:00
<img alt="XyTalk FS" src="http://111.230.157.216/img/upload.png" WIDTH="800" />
<br>
上传到七牛云效果:
<br>
<img alt="XyTalk FS" src="http://111.230.157.216/img/qiniufile.png" WIDTH="800"/>
<br>
上传到阿里云效果:
<br>
<img alt="XyTalk FS" src="http://111.230.157.216/img/alifile.png" WIDTH="800"/>
<br>
2018-07-26 17:31:38 +08:00
上传到Mongo GridFS效果:
<br>
<img alt="XyTalk FS" src="http://111.230.157.216/img/gridfsfile.png" WIDTH="800" />
<br>
上传到SeaweedFS效果:
<br>
<img alt="XyTalk FS" src="http://111.230.157.216/img/seaweedf1.png" WIDTH="800" />
<br>
程序调试输出:
<br>
<img alt="XyTalk FS" src="http://111.230.157.216/img/fsdebug.png" WIDTH="800" />
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
#### 安装、使用教程
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
- 1、Import Gradle Project
- 2、点击工程右键Gradle>>Refresh Gradle Project
2018-07-24 16:54:30 +08:00
- 3、运行方法右键“FileSystemApplication.java”点击“run as”--“Java App..”。或者选择Gradle Task栏点击“bootRun”
2018-07-09 16:28:56 +08:00
- 4、如果出现以下信息说明运行时环境已经完成
2018-07-24 17:00:36 +08:00
2018-07-09 16:28:56 +08:00
<br>
2018-07-09 16:06:56,794 INFO (StartupInfoLogger.java:59)- Started FileSystemApplication in 14.575 seconds (JVM running for 15.457)
<br>
2018-07-24 16:54:30 +08:00
如果出现Exception opening socketlocalhost:27017异常 不必惊慌只是mongodb未安装而已不影响系统使用。
<br>
2018-07-24 17:00:36 +08:00
访问:
2018-07-09 16:28:56 +08:00
<br>
2018-07-25 11:06:20 +08:00
http://localhost:9091/files/index/
2018-07-25 11:08:02 +08:00
2018-07-09 16:43:35 +08:00
<br>
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
### 开发配置
可以在配置文件application.properties里修改属性
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
例如
tomcat服务端口
server.port=9091
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
是否重新命名文件名如果是个人文件则重命名为username_ + 原文件名如果是群组文件则重命名为groupid_ + 原文件名
storage.rename = true
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
存储源.可多选.可以同时储存多个数据源,便于备份
类型有xyfs\\Seafile\\FastDFS\\SeaweedFS\\MongoDB\\aliOSS\\qiniu\\CFS
2018-07-24 16:54:30 +08:00
- storage.todisk = true
- storage.toqiniu = true
- storage.tofastdfs = false
- storage.tomongodb = false
- storage.toseaweedfs = false
- storage.toalioss = false
- storage.tocfs = false
2018-07-03 10:12:23 +08:00
2018-07-09 16:28:56 +08:00
设置下载的源 ,单选
类型有xyfs\\Seafile\\FastDFS\\SeaweedFS\\MongoDB\\aliOSS\\qiniu\\CFS
2018-07-24 16:54:30 +08:00
- storage.downloadfrom = xyfs
2018-07-03 10:12:23 +08:00
2018-07-09 16:30:21 +08:00
2018-07-09 16:32:24 +08:00
### 全部配置:
<pre><code># tomcat服务端口 #
2018-07-09 16:30:21 +08:00
server.port=9091
#启用shutdown
endpoints.sensitive=false
# 存储的相对路径,如果 storage.source = xyfs 需要配置 #
storage.location = uploadfiledir
# 是否重新命名文件名如果是个人文件则重命名为username_ + 原文件名如果是群组文件则重命名为groupid_ + 原文件名 #
storage.rename = true
# 存储源.可多选.可以同时储存多个数据源,便于备份 #
# 类型有xyfs\\Seafile\\FastDFS\\SeaweedFS\\MongoDB\\aliOSS\\qiniu\\CFS #
storage.todisk = true
storage.toqiniu = true
storage.tofastdfs = false
storage.tomongodb = false
storage.toseaweedfs = false
storage.toalioss = false
storage.tocfs = false
# 用于设置下载的源 ,单选 #
# 类型有xyfs\\Seafile\\FastDFS\\SeaweedFS\\MongoDB\\aliOSS\\qiniu\\CFS #
storage.downloadfrom = xyfs
# xyfs存储配置 #
storage.diskprefix = http://localhost:9091/files/
# 七牛存储配置 #
storage.qiniuprefix = http://pbby0yzdu.bkt.clouddn.com/
storage.qiniuak = _IAafy8aX5x7h-4FBEvH2DqCtTq2c7sESPSlfG
storage.qiniusk = _8hy2LE6kfTKr3wDUWJONgFRxPKX4cDQhi79Bj
storage.qiniubucket = xytalk
# mongodb.gridfs配置 #
storage.gridfshost = 127.0.0.1
storage.gridfsdbname = xyfs
storage.gridfsport = 27017
storage.gridfscollectionname = fs
# fastDFS 配置 #
storage.fastdfsconnecttimeout = 5
storage.fastdfsnetwork_timeout = 10
storage.fastdfscharset = UTF-8
storage.fastdfstrackerhttpport = 80
storage.fastdfsantistealtoken = no
storage.fastdfssecret_key = 1234567890
storage.fastdfstrackerserver = 192.168.17.112:22122
# SeaweedFS 配置 #
storage.seaweedfshost = localhost
storage.seaweedfsport = 9333
storage.seaweedfstimeout = 10
# ali OSS 配置 #
storage.aliendpoint = ""
storage.aliaccesskeyid = ""
storage.aliaccesskeysecret = ""
storage.alibucketname = ""
storage.alidownloadkey = ""
# 第一次使用的配置自动创建数据库表如果是运行SQL脚本则无需使用此配置 #
# spring.jpa.hibernate.ddl-auto = create
# 第二次开始使用的配置据库表会根据Entity的变动而更新 #
spring.jpa.hibernate.ddl-auto = update
# Sqlite数据源 #
spring.datasource.driver-class-name=org.sqlite.JDBC
spring.datasource.url=jdbc:sqlite:DbSqlite/xyfs.db
spring.datasource.platform=sqlite
spring.jpa.database-platform= xy.FileSystem.Dialect.SQLiteDialect
# mysql数据源 #
#spring.datasource.url=jdbc:mysql://localhost:3306/xyfs
#spring.datasource.username=root
#spring.datasource.password=mysql
# oracle数据源 #
#spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
#spring.datasource.url=jdbc:oracle:thin:@127.0.0.1:1521:torcl
#spring.datasource.username=center
#spring.datasource.password=centerDB12345
# dbcp2连接池配置 #
spring.datasource.type=org.apache.commons.dbcp2.BasicDataSource
spring.datasource.dbcp2.max-wait-millis=10000
spring.datasource.dbcp2.min-idle=5
spring.datasource.dbcp2.initial-size=5
spring.datasource.dbcp2.validation-query=SELECT 1 FROM app
spring.datasource.dbcp2.connection-properties=characterEncoding=utf8
# druid连接池的配置信息 #
#spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#spring.datasource.initialSize=5
#spring.datasource.minIdle=5
#spring.datasource.maxActive=20
#spring.datasource.maxWait=60000
#spring.datasource.timeBetweenEvictionRunsMillis=60000
#spring.datasource.minEvictableIdleTimeMillis=300000
#spring.datasource.validationQuery=SELECT 1 FROM App
#spring.datasource.testWhileIdle=true
#spring.datasource.testOnBorrow=false
#spring.datasource.testOnReturn=false
#spring.datasource.poolPreparedStatements=true
#spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
#spring.datasource.filters=stat,wall,log4j
# spring jackson 时间配置 #
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.joda-date-time-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8
# multipart 上传配置 #
spring.servlet.multipart.enabled=true
spring.servlet.multipart.max-file-size=1024MB
spring.servlet.multipart.max-request-size=1024MB
# oss 日志配置 #
logging.config=classpath:logback.xml
</code></pre>