如何保证某个程序系统内只运行一个,保证原子性

java 复制代码
	@GetMapping("/startETL")
//	@Idempotent(expireTime = 90, info = "请勿90秒内连续点击")
	public R getGaugeTestData6() {
		log.info("start ETL");
		//redis设置t_data_load_record 值为2
		bladeRedis.set("t_data_load_record_type", 2);
		String s = atomicityService.startETL();
		return R.data(s);
	}
java 复制代码
@Slf4j
@Service
public class AtomicityService {


	@Autowired
	private DataSourceService dataSourceService;


	// 使用 AtomicBoolean 作为互斥标志
	private final AtomicBoolean isExecuting = new AtomicBoolean(false);
	private final AtomicBoolean isExecutingForXRRJ = new AtomicBoolean(false);

	public String startETL() {
		if (isExecuting.compareAndSet(false, true)) {
			try {
				long startTime = System.currentTimeMillis(); // 记录开始时间
				ETLExecutionThreadLocal.setStartTime(startTime);
				// 执行 ETL 任务的具体逻辑
				//查询已经存在的数据的 批次号和站点号 做排除用
				List batchSiteList = dataSourceService.ReadBatchSiteList();
				List<Long> batchList = dataSourceService.ReadBatchList();
				List<Long> testerList = null;//测试人还是全删除吧,不要做增量查询,否则有些人被更新过信息进不来
				//读取数据源
				dataSourceService.ReadDataSource(batchSiteList, batchList, testerList);
				long endTime = System.currentTimeMillis();
				long executionTimeSeconds = (endTime - startTime) / 1000; // 计算用时(秒)
				return "ETL执行成功,用时:" + executionTimeSeconds + "秒";
			} finally {
				isExecuting.set(false);
			}
		} else {
			// 如果定时任务执行期间有手动执行请求,则驳回
			log.info("任务已经在执行中,本次请求被驳回");
			return "任务已经在执行中,本次请求被驳回";
		}
	}

定时任务在此与其共用一个程序,两者不可同时执行

java 复制代码
package org.springblade.etl.source.task;

import lombok.extern.slf4j.Slf4j;
import org.springblade.core.redis.cache.BladeRedis;
import org.springblade.core.tool.api.R;
import org.springblade.etl.source.service.AtomicityService;
import org.springblade.etl.source.service.DataSourceService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.util.List;
import java.util.Map;

@Component
@Slf4j
public class ETLJob {

	// 注入 dataSourceService
	@Resource
	private AtomicityService atomicityService;

	@Resource
	private BladeRedis bladeRedis;
	@Scheduled(cron = "0 0 1 * * ?") // 每天凌晨1点执行一次
	public void executeETL() {
		// 执行 startETL 方法
		log.info("Scheduled ETL job started");
		bladeRedis.set("t_data_load_record_type", 1);
		R result = getGaugeTestData6();
		log.info("ETL job finished with result: " + result);
	}

	// 在此处定义 getGaugeTestData6 方法的具体实现
	public R getGaugeTestData6() {
		log.info("start for Scheduled ETL job");
		atomicityService.startETL();
		return R.data("success for Scheduled ETL job");
	}


//	@Scheduled(cron = "0/1 * * * * ?") // 每秒执行一次
//	public void executeTestJob() {
//		log.info("定时任务执行测试");
//	}
}
相关推荐
要加油哦~9 小时前
JS | 知识点总结 - 原型链
开发语言·javascript·原型模式
Deschen4 天前
设计模式-原型模式
java·设计模式·原型模式
冰糖雪梨dd6 天前
JS中new的过程发生了什么
开发语言·javascript·原型模式
white-persist9 天前
SQL 注入详解:从原理到实战
前端·网络·数据库·sql·安全·web安全·原型模式
white-persist9 天前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
魔云连洲12 天前
深入解析:Object.prototype.toString.call() 的工作原理与实战应用
前端·javascript·原型模式
white-persist13 天前
Burp Suite模拟器抓包全攻略
前端·网络·安全·web安全·notepad++·原型模式
青草地溪水旁14 天前
第五章:原型模式 - 克隆大法的大师
c++·设计模式·原型模式
white-persist14 天前
【burp手机真机抓包】Burp Suite 在真机(Android and IOS)抓包手机APP + 微信小程序详细教程
android·前端·ios·智能手机·微信小程序·小程序·原型模式
XiaoLeisj18 天前
【SpringAI】第四弹:深入解析 Rag 检索增强工作流程、最佳实践和调优
阿里云·原型模式·rag·spring ai·灵积大模型