项目中遇到一个场景,需要记录每次最新处理的数据库表的index。比如上一次查询到的表行数为1000,本次查询到的表行数为2000,需要处理的是1001到2000这些新增数据。
初步考虑到解决方案有两种:一、存数据库;二、存配置文件
由于业务场景是一个触发频率较低的定时任务,所以采用存配置文件的方式。OK,现在言归正传。
方案一
- 在启动类Applaction使用@EnableConfigurationProperties注解
- 使用@ConfigureProperties定义一个专门表示配置文件属性的类
- 直接使用bean的get/set存取即可
注:使用这种方式,每次服务重启时属性值会恢复配置文件初值
所以上述方案并不能满足我的需求
方案二
yaml文件定义
test:
num: 1
使用文件io读取写入
public static int getNum() throws IOException {
Yaml yaml = new Yaml();
File file = ResourceUtils.getFile("classpath:test.yaml");
Map m1 = (Map)yaml.load(new FileInputStream(file));
Map m2 = (Map)m1.get("test");
return (int)m2.get("num");