org.apache.shardingsphere.data.pipeline.api.RuleAlteredJobAPI Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.shardingsphere.data.pipeline.api;
import org.apache.shardingsphere.data.pipeline.api.check.consistency.DataConsistencyCheckResult;
import org.apache.shardingsphere.data.pipeline.api.config.rulealtered.RuleAlteredJobConfiguration;
import org.apache.shardingsphere.data.pipeline.api.job.progress.JobProgress;
import org.apache.shardingsphere.data.pipeline.api.pojo.DataConsistencyCheckAlgorithmInfo;
import org.apache.shardingsphere.data.pipeline.api.pojo.JobInfo;
import org.apache.shardingsphere.spi.type.required.RequiredSPI;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Properties;
/**
* Rule altered job API.
*/
public interface RuleAlteredJobAPI extends PipelineJobAPI, RequiredSPI {
/**
* List all jobs.
*
* @return job infos
*/
List list();
/**
* Start scaling job by config.
*
* @param jobConfig job config
* @return job id
*/
Optional start(RuleAlteredJobConfiguration jobConfig);
/**
* Get job progress.
*
* @param jobId job id
* @return each sharding item progress
*/
Map getProgress(String jobId);
/**
* Get job progress.
*
* @param jobConfig job configuration
* @return each sharding item progress
*/
Map getProgress(RuleAlteredJobConfiguration jobConfig);
/**
* Stop cluster writing.
*
* @param jobId job id
*/
void stopClusterWriteDB(String jobId);
/**
* Stop cluster writing.
*
* @param databaseName database name
* @param jobId job id
*/
void stopClusterWriteDB(String databaseName, String jobId);
/**
* Restore cluster writing.
*
* @param jobId job id
*/
void restoreClusterWriteDB(String jobId);
/**
* Restore cluster writing.
*
* @param databaseName database name
* @param jobId job id
*/
void restoreClusterWriteDB(String databaseName, String jobId);
/**
* List all data consistency check algorithms from SPI.
*
* @return data consistency check algorithms
*/
Collection listDataConsistencyCheckAlgorithms();
/**
* Is data consistency check needed.
*
* @param jobId job id
* @return data consistency check needed or not
*/
boolean isDataConsistencyCheckNeeded(String jobId);
/**
* Is data consistency check needed.
*
* @param jobConfig job configuration
* @return data consistency check needed or not
*/
boolean isDataConsistencyCheckNeeded(RuleAlteredJobConfiguration jobConfig);
/**
* Do data consistency check.
*
* @param jobId job id
* @return each logic table check result
*/
Map dataConsistencyCheck(String jobId);
/**
* Do data consistency check.
*
* @param jobConfig job configuration
* @return each logic table check result
*/
Map dataConsistencyCheck(RuleAlteredJobConfiguration jobConfig);
/**
* Do data consistency check.
*
* @param jobId job id
* @param algorithmType algorithm type
* @param algorithmProps algorithm props. Nullable
* @return each logic table check result
*/
Map dataConsistencyCheck(String jobId, String algorithmType, Properties algorithmProps);
/**
* Aggregate data consistency check results.
*
* @param jobId job id
* @param checkResults check results
* @return check success or not
*/
boolean aggregateDataConsistencyCheckResults(String jobId, Map checkResults);
/**
* Switch cluster configuration.
*
* @param jobId job id
*/
void switchClusterConfiguration(String jobId);
/**
* Switch cluster configuration.
*
* @param jobConfig job configuration
*/
void switchClusterConfiguration(RuleAlteredJobConfiguration jobConfig);
/**
* Reset scaling job.
*
* @param jobId job id
*/
void reset(String jobId);
/**
* Get job configuration.
*
* @param jobId job id
* @return job configuration
*/
RuleAlteredJobConfiguration getJobConfig(String jobId);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy