# version-spring-boot-starter
**Repository Path**: alex200816/version-spring-boot-starter
## Basic Information
- **Project Name**: version-spring-boot-starter
- **Description**: 版本自动升级,无网环境应用或单机版应用自动升级,每个版本升级可运行自定义SQL脚本及自定义Java代码
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 3
- **Forks**: 0
- **Created**: 2024-08-25
- **Last Updated**: 2025-04-30
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# 单机应用自动升级工具
## 介绍
以往部署单机版应用时,用户常常面临手动更新SQL和JAR包等繁琐操作,这不仅要求用户具备一定的技术背景,还容易在升级过程中出错,导致应用无法正常运行。为了解决这一难题,推出了这款专为单机应用设计的升级工具。
## 特点
**单机版设计,灵活便捷**:
本工具专为单机应用量身打造,无需网络连接即可轻松使用。无论您身处何地,只要集成本工具,就能随时随地进行软件升级,无需担心网络环境的限制。
**无网升级,安全可靠**:
与传统的在线升级方式不同,本工具采用离线升级模式,无需依赖网络连接。您只需将旧版的JAR包替换为新版,即可完成升级操作,既安全又可靠,避免了网络不稳定或数据泄露的风险。
**简便易用,一键升级**:
我们深知用户对于升级过程的担忧和困扰,因此本工具无需用户操作任何步骤。只需将旧JAR替换的操作,即可完成整个升级过程,无需繁琐的设置或特殊技能,真正实现无感升级。
**智能检测,自动升级**:
本工具内置智能检测功能,能够自动检测当前安装的软件版本,并与加载的最新版本进行比对。一旦发现新版本,将自动执行升级操作,无需您手动干预,让您及时享受最新功能。
**数据升级,无缝衔接**:
为了确保软件升级后数据的完整性和一致性,本工具在每个版本升级时都会自动执行相应的自定义SQL脚本用于升级数据库。在升级过程中,工具会自动执行这些SQL脚本,确保数据库结构与软件版本相匹配,实现无缝衔接。
**完全开源**:
本工具采用完全开源的设计理念,让您能够自由定制和扩展其功能。无论您是开发者还是技术爱好者,都能轻松上手,根据自己的需求进行个性化定制,打造属于自己的专属升级工具。
## 集成
### 示例
[查看示例工程](https://gitee.com/alex200816/version-spring-boot-starter/tree/master/sample)
### 文件目录
~~~ bash
src
|-- main
|-- java
|-- resources
|-- version # 主目录
|-- sql # 当前目录存放每个版本需要执行的SQL脚本
|-- 1.0.0.sql # 文件名称需与version.xml定义的版本号相同
|-- version.xml # 当前文件存放各个版本信息,及升级需要执行的操作
~~~
### 使用说明
**1、maven引入依赖**
~~~ xml
cn.002alex
version-spring-boot-starter
1.0.3
~~~
**2、启动类添加@EnableVersionUpdating注解**
~~~ java
@EnableVersionUpdating
@SpringBootApplication
public class SampleApplication {
public static void main(String[] args) {
SpringApplication.run(SampleApplication.class, args);
}
}
~~~
**3、application.yml配置示例**
~~~ yml
application-version:
# 是否启用自动升级
enable: true
# 当前JAR包版本
version: 1.0.0
# 版本信息保存地址
# 默认: {Jar路径}/config/version.config
# 如果使用Jar同目录下的其他路径可以使用{user.dir}/server/config/version.config
versionConfigPath:
~~~
**4、version.xml配置示例**
> 当前文件存放位置请看 **`文件目录`**
~~~ xml
1.0.0
2024-7-27 12:30:53
1.新增某某某功能
2.修复某某BUG
0
1.0.1
2024-7-27 12:30:53
1.新增某某某功能
2.修复某某BUG
~~~
**5、各版本SQL脚本配置示例**
> 需注意每条语句需加结束符 **`;`**,否则将出现无法预估的异常
~~~ mysql
update sys_user set pass_word = '123456' where user_name = '张三';
~~~
**6.每个版本执行回调**
ApplicationVersionCallback.java
~~~ java
import cn.alex.version.callback.VersionUpdatingCallback;
import cn.alex.version.callback.builder.VersionUpdatingCallbackBuilder;
import cn.alex.version.callback.builder.VersionUpdatingCallbackExceptionBuilder;
import cn.alex.version.callback.builder.VersionUpdatingCallbackStartBuilder;
import org.springframework.stereotype.Service;
/**
* 版本升级回调
*
* @author Alex
* @date 2024/8/31 04:54
*/
@Service
public class CustomCallBack implements VersionUpdatingCallback {
@Override
public void onStartCall(VersionUpdatingCallbackStartBuilder startBuilder) {
System.out.println("开始执行版本升级");
}
@Override
public void onUpdatingStartCall(VersionUpdatingCallbackBuilder updateBuilder) {
System.out.println("开始执行一个版本的升级");
}
@Override
public void onUpdatingEndCall(VersionUpdatingCallbackBuilder updateBuilder) {
System.out.println("结束执行一个版本升级");
}
@Override
public void onEndCall() {
System.out.println("结束执行版本升级回调");
}
@Override
public void onExceptionCall(VersionUpdatingCallbackExceptionBuilder exceptionBuilder) {
System.out.println("异常回调");
}
}
~~~