Skip to content

Latest commit

 

History

History
235 lines (184 loc) · 12.5 KB

README.md

File metadata and controls

235 lines (184 loc) · 12.5 KB

image diskMirror-starter

DiskMirror 的 starter,通过引入此类,可以直接实现 diskMirror 在 SpringBoot 中的自动配置,接下来我们将使用案例逐步的演示 diskMirror starter 的使用 需要注意的是,此 starter 最适用于 SpringBoot3 版本,且也推荐使用 SpringBoot3 版本的自动配置模块!!!

引入 starter

我们可以直接在 maven 中像下面这样配置好 starter,在下面我们引入了一些依赖,如果需要使用第三方文件系统适配器,则可以直接在 maven 中引入,如果您不需要第三方文件系统,可以不引入 根据您的需求来进行选择,如果您不知道需要的库有哪些,可以查阅 diskMirror 的主页

<dependencies>
    <!-- 导入 SpringBoot 项目的 starter 在这里我们使用的示例是 Web starter 您可以根据您的需要修改 starter 类型 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- 导入 DiskMirror 的 starter TODO 一般来说 只需要导入这个和其它的第三方文件系统依赖即可 -->
    <dependency>
        <groupId>io.github.BeardedManZhao</groupId>
        <artifactId>diskMirror-spring-boot-starter</artifactId>
        <version>1.0.5</version>
    </dependency>
    <!-- 导入 fastjson2 库 这是一个JSON解析库,被 diskMirror 依赖,您可以像上面一样导入 也是一个可选操作 -->
    <dependency>
        <groupId>com.alibaba.fastjson2</groupId>
        <artifactId>fastjson2</artifactId>
        <version>2.0.25</version>
    </dependency>
</dependencies>

版本对应列表

有时候您在使用 starter 的过程中,可能遇到一些版本不兼容的情况,他们可能会导致一些奇怪的问题,这里我们列一下兼容情况。

如果您不期望自己来进行版本对应的审查,您可以只导入 starter 即可, starter 会自动加载兼容的依赖。

starter版本 其支持的 diskMirror 版本 其支持的 zhao-utils 版本
<= 1.0.2 * *
>= 1.0.3 >= 1.3.0 >= 1.0.20241026

开发基本的 SpringBoot3 项目

在这里您可以根据一些简单的示例来了解如何使用 diskMirror 的盘镜 starter。

配置 starter

diskMirror 的 starter 配置文件具有默认数值,下面就是默认的配置文件,同样,您可以按照下面的示例来进行配置文件的修改。

PS 请将 enable-feature 设置为 true!!!

disk-mirror:
  # 此配置项目代表的就是是否启用 diskMirror 如果设置为 false 则代表不启用,diskMirror 的starter 将不会被加载
  enabled-feature: false
  # 要使用的盘镜适配器类型 在这里默认数值是本地盘镜适配器,具体的适配器 您可以查阅 top.lingyuzhao.diskMirror.core.DiskMirror 类
  adapter-type: "LocalFSAdapter"
  # 要被盘镜管理的目录 用于存储数据的目录 此目录是真实目录
  root-dir: "/DiskMirror"
  # 一般来说 如果对接带第三方文件系统 而非本次文件系统 则此参数则会派上用场,其代表的就是第三方文件系统的地址
  fs-default-fs: "hdfs://localhost:8020/"
  # 当处理之后,如果处理无错误会返回一个结果状态,此数值代表的就是是否正确处理
  ok-value: "ok!!!!"
  # 返回结果的key 返回结果中 结果状态的字段名字
  res-key: "res"
  # 协议前缀,默认为http 不同协议前缀有不同的意义,用于拼接 url
  protocol-prefix: "http://localhost:80/"
  # 参数 可能会派上用场,在不同的适配器中有不同的实现
  params: { }
  # 用户磁盘配额 每个盘镜空间的磁盘最大空间数值,单位是字节
  user-disk-mirror-space-quota: 134217728
  # 安全密钥
  secure-key: ""
  # 指定的几个用户的空间对应的容量
  space-max-size: { }
  # 图像文件压缩模块配置
  image-compress-module:
    # 设置位 true 代表启用~ 反之则不启用 不启用的将不会被加载到 diskMirror 中
    enable: true
    # 设置 png 调色板模式 默认是 RGB_8 代表 8 位压缩
    palette-png: "RGB_8"
    # 设置 调色板生成器,默认是 X255
    palette-generator: "X255"
    # 设置是否支持透明 默认是 false
    transparent: false
  # 设置校验模块
  verifications:
    # 设置读取操作中的 sk 校验 这样所有的读取操作都需要经过这个模块了
    - "SkCheckModule$read",
    # 设置写入操作中的 sk 校验 这样所有的写入操作都需要经过这个模块了
    - "SkCheckModule$writer"

MAIN 启动主类

在这里我们为了演示清晰,没有使用复杂架构,直接使用了一个启动主类,也没有设置其它的控制器。

package com.example.springboot3demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;
import top.lingyuzhao.diskMirror.conf.Config;
import top.lingyuzhao.diskMirror.core.Adapter;

@SpringBootApplication
// 使用此扫描器对 top.lingyuzhao.diskMirror.starter 包进行扫描,就可以实现自动配置了
@ComponentScan("top.lingyuzhao.diskMirror.starter")
public class SpringBoot3DemoApplication {

    public static void main(String[] args) {
        // 获取到运行器上下文
        final var run = SpringApplication.run(SpringBoot3DemoApplication.class, args);
        // 查看一下 diskMirror 是否被加载进来了
        System.out.println(run.getBean(Adapter.class).getConfig().get(Config.PROTOCOL_PREFIX));
    }

}

启动测试

当看到下面这样的日志,则代表启动成功了,diskMirror 也被成功的集成了进来!!

19:47:13.595 [main] INFO top.lingyuzhao.diskMirror.backEnd.springConf.DiskMirrorMAIN -- 允许跨域列表:[]

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::                (v3.0.5)

2024-12-05T19:47:13.844+08:00  INFO 44908 --- [           main] t.l.d.backEnd.springConf.DiskMirrorMAIN  : Starting DiskMirrorMAIN using Java 17.0.12 with PID 44908 (F:\MyGithub\diskMirror-backEnd-spring-boot\target\classes started by zhao in F:\MyGithub\diskMirror-backEnd-spring-boot)
2024-12-05T19:47:13.845+08:00  INFO 44908 --- [           main] t.l.d.backEnd.springConf.DiskMirrorMAIN  : No active profile set, falling back to 1 default profile: "default"
2024-12-05T19:47:14.377+08:00  INFO 44908 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2024-12-05T19:47:14.383+08:00  INFO 44908 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2024-12-05T19:47:14.383+08:00  INFO 44908 --- [           main] o.apache.catalina.core.StandardEngine    : Starting Servlet engine: [Apache Tomcat/10.1.7]
2024-12-05T19:47:14.437+08:00  INFO 44908 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2024-12-05T19:47:14.437+08:00  INFO 44908 --- [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 567 ms
2024-12-05T19:47:14.462+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setEnableFeature run = enableFeature:true
2024-12-05T19:47:14.462+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setAdapterType run = adapterType:LocalFSAdapter
2024-12-05T19:47:14.462+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setFsDefaultFs run = fsDefaultFs:hdfs://localhost:8020/
2024-12-05T19:47:14.463+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setImageCompressModule run = imageCompressModule:ImageCompressModule
2024-12-05T19:47:14.522+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setParams run = params:{}
2024-12-05T19:47:14.523+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setProtocolPrefix run = protocolPrefix:
2024-12-05T19:47:14.523+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setResKey run = resKey:res
2024-12-05T19:47:14.523+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setRootDir run = rootDir:/DiskMirror
2024-12-05T19:47:14.523+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setSecureKey run = secureKey:
2024-12-05T19:47:14.524+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setSpaceMaxSize run = spaceMaxSize:{}
2024-12-05T19:47:14.524+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : setUserDiskMirrorSpaceQuota run = userDiskMirrorSpaceQuota:1073741824
2024-12-05T19:47:14.526+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : 已加载 read 模块:SkCheckModule
2024-12-05T19:47:14.527+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : 已加载 writer 模块:SkCheckModule
2024-12-05T19:47:14.527+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : getAdapterType run = adapterType:LocalFSAdapter
2024-12-05T19:47:14.529+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : loadHandleModule ---> Enable  handleModule.ImageCompressModule
2024-12-05T19:47:14.529+08:00  INFO 44908 --- [           main] t.l.d.s.c.DiskMirrorAutoConfiguration    : diskMirror is ok!!!
+--------------------------------------------------+
| https://github.com/BeardedManZhao/DiskMirror.git |
+--------------------------------------------------+
     \   _     _  
      \ (c).-.(c) 
         / ._. \  
       __\( Y )/__
      (_.-/'-'\-._) LocalFSAdapter:1.3.5
    ____  _      __   __  ____                 ____ 
   / __ \(_)____/ /__/  |/  (_)_____________  / __ \
  / / / / / ___/ //_/ /|_/ / / ___/ ___/ __ \/ /_/ /
 / /_/ / (__  ) ,< / /  / / / /  / /  / /_/ / _, _/ 
/_____/_/____/_/|_/_/  /_/_/_/  /_/   \____/_/ |_|  

2024-12-05T19:47:14.531+08:00  INFO 44908 --- [           main] t.l.d.backEnd.springConf.DiskMirrorMAIN  : diskMirror 明文密钥:"" 被解析为数字密钥:0

如何使用 diskMirror 的适配器?

通过 starter 获取到的就是 diskMirror 中的适配器对象,您可以通过适配器对象实现有效的文件操作,具体使用方法请参考 diskMirror 的主页

更新记录

1.0.5

发布时间:2024-12-05

  • 支持使用 verifications 配置,进行 sk 等请求处理器的注册操作!
  • 装载 1.3.5 版本的 diskMirror

1.0.4

发布时间:2024-11-22

  • 对于限定条件进行了优化,且对于异常的信息和日志打印进行了优化,易于排查
  • 装载了 1.3.2 版本的 diskMirror

1.0.3

发布时间:2024-11-02

  • 新增了 image-compress-module 模块的配置,其可以直接对接到 DiskMirror v1.3.0 中的处理模块管理器中~

1.0.2

发布时间:2024-02-23

  • 针对配置文件的默认数值进行的设定,这使得您可能不需要在配置文件中将所有配置项目进行设置
  • 变更了适配器Bean 在 SpringBoot 中的Bean 的名字,这有助于避免一些命名冲突问题,变更的情况为 getAdapter -> top.lingyuzhao.diskMirror.core.Adapter

1.0.1

发布时间:2024-02-14

  • 增加了 enable-feature 配置项,使得您可以通过调整此参数来实现是否要启动 diskMirror 的 starter,减少了需要变更 pom.xml 的风险。
  • 增加了针对 zhao-utils 库的自动依赖,您可以不去声明此库的依赖,diskMirror starter 会自动依赖它。

更多