博客
关于我
Spring Boot 动态加载jar包,动态配置太强了!
阅读量:796 次
发布时间:2023-02-26

本文共 894 字,大约阅读时间需要 2 分钟。

数据治理服务动态加载与卸载方案

概述

本文提出了一种支持动态加载与卸载的数据治理服务方案,旨在解决现有服务升级或新增治理任务时导致其他任务中断的问题。

动态加载

1. 自定义类加载器

为了实现动态加载功能,开发了一种自定义类加载器MyClassLoader,基于URLClassLoader,能够动态加载外部JAR包或类文件。该加载器配备类卸载机制,确保资源回收。

  • 实现细节:自定义加载器维护一个类加载记录表loadedClasses,用于跟踪已加载的类。卸载时通过反射调用类的destroy方法,确保资源释放。

2. 系统集成

  • Spring整合:通过动态扫描机制,将带有@Spring注解的类自动注册至Spring容器。
  • XXL-JOB集成:将定义的治理任务作为XXL-JOB任务注册到XXL-JOB执行器中,实现统一管理。

动态卸载

卸载流程

动态卸载分为以下步骤:

  • 清理XXL-JOB任务:从jobHandlerRepository中移除相关任务配置。
  • Spring bean卸载:从Spring容器中移除相关bean定义,确保资源释放。
  • 类加载器卸载:从ClassLoader中移除已加载的类,并调用unload方法。
  • 动态配置

    为了支持动态调整配置,采用以下方式:

    1. 动态修改本地YAML

    • 依赖引入:添加snakeyaml库,支持动态读写YAML配置文件。
    • 工具类开发:通过读取并修改bootstrap.yml文件,实现动态调整加载任务的配置。

    2. Nacos动态配置

    • 集成Nacos:利用Spring Cloud Alibaba Nacos,通过代码动态修改配置文件。
    • 实现细节:读取并解析配置文件,动态更新Nacos存储,确保配置实时生效。

    分离打包

    在项目打包时,采用Maven Shade插件进行依赖打包,实现依赖的动态加载。通过配置插件filters,指定需要打包的源文件,确保动态加载模块独立打包,便于管理和更新。

    总结

    该方案通过动态加载与卸载机制,确保数据治理服务的高可用性,支持业务代码的灵活扩展和配置管理,有效解决了现有服务升级中对其他任务的影响问题。

    转载地址:http://yxvfk.baihongyu.com/

    你可能感兴趣的文章
    OS第2章 —— 进程
    查看>>
    OS第3章 —— 进程调度和死锁
    查看>>
    OS第5章
    查看>>
    OS第6章 —— 设备管理
    查看>>
    OTA测试
    查看>>
    Outlook 2010 Inside Out
    查看>>
    overlay(VLAN,VxLAN)、underlay网络、大二层概述
    查看>>
    OWASP漏洞原理<最基础的数据库 第二课>
    查看>>
    OWL本体语言
    查看>>
    P with Spacy:自定义文本分类管道
    查看>>
    P1035 I need help
    查看>>
    P1364 医院设置
    查看>>
    P2260 [清华集训2012]模积和
    查看>>
    SpringBoot中集成influxdb-java实现连接并操作Windows上安装配置的influxDB(时序数据库)
    查看>>
    P8738 [蓝桥杯 2020 国 C] 天干地支
    查看>>
    package.json文件常用指令说明
    查看>>
    SpringBoot中集成eclipse.paho.client.mqttv3实现mqtt客户端并支持断线重连、线程池高并发改造、存储入库mqsql和redis示例业务流程,附资源下载
    查看>>
    Padding
    查看>>
    paddlehub安装及对口罩检测
    查看>>
    SpringBoot中集成Actuator实现监控系统运行状态
    查看>>