View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package org.apache.shardingsphere.data.pipeline.core.consistencycheck;
19  
20  import lombok.Getter;
21  import lombok.RequiredArgsConstructor;
22  import lombok.Setter;
23  import org.apache.shardingsphere.data.pipeline.core.job.progress.listener.PipelineJobProgressListener;
24  import org.apache.shardingsphere.data.pipeline.core.job.progress.listener.PipelineJobProgressUpdatedParameter;
25  import org.apache.shardingsphere.data.pipeline.core.job.progress.persist.PipelineJobProgressPersistService;
26  
27  import java.util.Collection;
28  import java.util.Map;
29  import java.util.concurrent.ConcurrentHashMap;
30  import java.util.concurrent.CopyOnWriteArraySet;
31  import java.util.concurrent.atomic.AtomicLong;
32  
33  /**
34   * Consistency check job item progress context.
35   */
36  @RequiredArgsConstructor
37  @Getter
38  @Setter
39  public final class ConsistencyCheckJobItemProgressContext implements PipelineJobProgressListener {
40      
41      private final String jobId;
42      
43      private final int shardingItem;
44      
45      private final Collection<String> tableNames = new CopyOnWriteArraySet<>();
46      
47      private final Collection<String> ignoredTableNames = new CopyOnWriteArraySet<>();
48      
49      private volatile long recordsCount;
50      
51      private final AtomicLong checkedRecordsCount = new AtomicLong(0L);
52      
53      private final long checkBeginTimeMillis = System.currentTimeMillis();
54      
55      private volatile Long checkEndTimeMillis;
56      
57      private final Map<String, Object> sourceTableCheckPositions = new ConcurrentHashMap<>();
58      
59      private final Map<String, Object> targetTableCheckPositions = new ConcurrentHashMap<>();
60      
61      private final String sourceDatabaseType;
62      
63      @Override
64      public void onProgressUpdated(final PipelineJobProgressUpdatedParameter param) {
65          checkedRecordsCount.addAndGet(param.getProcessedRecordsCount());
66          PipelineJobProgressPersistService.notifyPersist(jobId, shardingItem);
67      }
68  }