From 86f0791a4f0a2e621a7c158bc61474b07253e651 Mon Sep 17 00:00:00 2001 From: taojinlong Date: Thu, 29 Jul 2021 12:15:40 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E4=BB=BB=E5=8A=A1=E5=88=97=E8=A1=A8?= =?UTF-8?q?=E4=B8=8A=E6=AC=A1=E6=89=A7=E8=A1=8C=E6=97=B6=E9=97=B4=E4=B8=8E?= =?UTF-8?q?=E6=89=A7=E8=A1=8C=E8=AE=B0=E5=BD=95=E6=89=A7=E8=A1=8C=E6=97=B6?= =?UTF-8?q?=E9=97=B4=E4=B8=8D=E4=B8=80=E8=87=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../dataset/DataSetTableTaskService.java | 5 +++-- .../service/dataset/ExtractDataService.java | 17 ++++++++++------- .../src/views/system/task/DatasetTaskList.vue | 2 +- 3 files changed, 14 insertions(+), 10 deletions(-) diff --git a/backend/src/main/java/io/dataease/service/dataset/DataSetTableTaskService.java b/backend/src/main/java/io/dataease/service/dataset/DataSetTableTaskService.java index 248ac860b5..83af70f621 100644 --- a/backend/src/main/java/io/dataease/service/dataset/DataSetTableTaskService.java +++ b/backend/src/main/java/io/dataease/service/dataset/DataSetTableTaskService.java @@ -117,7 +117,8 @@ public class DataSetTableTaskService { example.or(example.createCriteria().andIdEqualTo(datasetTable.getId()).andSyncStatusIsNull()); Boolean existSyncTask = datasetTableMapper.updateByExampleSelective(datasetTable, example) == 0; if(!existSyncTask){ - datasetTableTask.setLastExecTime(System.currentTimeMillis()); + Long startTime = System.currentTimeMillis(); + datasetTableTask.setLastExecTime(startTime); datasetTableTask.setLastExecStatus(JobStatus.Underway.name()); datasetTableTask.setStatus(TaskStatus.Exec.name()); update(datasetTableTask); @@ -125,7 +126,7 @@ public class DataSetTableTaskService { datasetTableTaskLog.setTableId(datasetTableTask.getTableId()); datasetTableTaskLog.setTaskId(datasetTableTask.getId()); datasetTableTaskLog.setStatus(JobStatus.Underway.name()); - datasetTableTaskLog.setStartTime(System.currentTimeMillis()); + datasetTableTaskLog.setStartTime(startTime); datasetTableTaskLog.setTriggerType(TriggerType.Custom.name()); dataSetTableTaskLogService.save(datasetTableTaskLog); } diff --git a/backend/src/main/java/io/dataease/service/dataset/ExtractDataService.java b/backend/src/main/java/io/dataease/service/dataset/ExtractDataService.java index e49ee0bfa4..822521234f 100644 --- a/backend/src/main/java/io/dataease/service/dataset/ExtractDataService.java +++ b/backend/src/main/java/io/dataease/service/dataset/ExtractDataService.java @@ -124,7 +124,7 @@ public class ExtractDataService { "fi\n" + "rm -rf %s\n"; - public synchronized boolean existSyncTask(DatasetTable datasetTable, DatasetTableTask datasetTableTask) { + public synchronized boolean existSyncTask(DatasetTable datasetTable, DatasetTableTask datasetTableTask, Long startTime) { datasetTable.setSyncStatus(JobStatus.Underway.name()); DatasetTableExample example = new DatasetTableExample(); example.createCriteria().andIdEqualTo(datasetTable.getId()).andSyncStatusNotEqualTo(JobStatus.Underway.name()); @@ -141,7 +141,7 @@ public class ExtractDataService { } return true; } else { - datasetTableTask.setLastExecTime(System.currentTimeMillis()); + datasetTableTask.setLastExecTime(startTime); datasetTableTask.setLastExecStatus(JobStatus.Underway.name()); datasetTableTask.setStatus(TaskStatus.Exec.name()); dataSetTableTaskService.update(datasetTableTask); @@ -238,12 +238,13 @@ public class ExtractDataService { LogUtil.info("Skip synchronization task, task ID : " + datasetTableTask.getId()); return; } - if (existSyncTask(datasetTable, datasetTableTask)) { + + Long startTime = System.currentTimeMillis(); + if (existSyncTask(datasetTable, datasetTableTask, startTime)) { LogUtil.info("Skip synchronization task for dataset, dataset ID : " + datasetTableId); return; } - - DatasetTableTaskLog datasetTableTaskLog = getDatasetTableTaskLog(datasetTableId, taskId); + DatasetTableTaskLog datasetTableTaskLog = getDatasetTableTaskLog(datasetTableId, taskId, startTime); UpdateType updateType = UpdateType.valueOf(type); if (context != null) { datasetTable.setQrtzInstance(context.getFireInstanceId()); @@ -520,11 +521,12 @@ public class ExtractDataService { } } - private DatasetTableTaskLog getDatasetTableTaskLog(String datasetTableId, String taskId) { + private DatasetTableTaskLog getDatasetTableTaskLog(String datasetTableId, String taskId, Long startTime) { DatasetTableTaskLog datasetTableTaskLog = new DatasetTableTaskLog(); datasetTableTaskLog.setTableId(datasetTableId); datasetTableTaskLog.setTaskId(taskId); datasetTableTaskLog.setStatus(JobStatus.Underway.name()); + datasetTableTaskLog.setTriggerType(TriggerType.Custom.name()); for (int i = 0; i < 5; i++) { List datasetTableTaskLogs = dataSetTableTaskLogService.select(datasetTableTaskLog); if (CollectionUtils.isNotEmpty(datasetTableTaskLogs)) { @@ -535,7 +537,8 @@ public class ExtractDataService { } catch (Exception ignore) { } } - datasetTableTaskLog.setStartTime(System.currentTimeMillis()); + datasetTableTaskLog.setTriggerType(TriggerType.Cron.name()); + datasetTableTaskLog.setStartTime(startTime); dataSetTableTaskLogService.save(datasetTableTaskLog); return datasetTableTaskLog; } diff --git a/frontend/src/views/system/task/DatasetTaskList.vue b/frontend/src/views/system/task/DatasetTaskList.vue index fcad1c51cd..c6da2df83b 100644 --- a/frontend/src/views/system/task/DatasetTaskList.vue +++ b/frontend/src/views/system/task/DatasetTaskList.vue @@ -47,7 +47,7 @@