All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cloud.task.impl.ShardingOperateServiceImpl Maven / Gradle / Ivy

package com.cloud.task.impl;

import com.cloud.task.api.IShardingOperateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.dangdang.ddframe.job.lite.internal.storage.JobNodePath;
import com.dangdang.ddframe.job.reg.base.CoordinatorRegistryCenter;

/**
 * 操作分片的实现类.
 *
 */
@Service
public final class ShardingOperateServiceImpl implements IShardingOperateService {

    @Autowired
    private CoordinatorRegistryCenter regCenter;

    @Override
    public void disable(final String jobName, final String item) {
        disableOrEnableJobs(jobName, item, true);
    }

    @Override
    public void enable(final String jobName, final String item) {
        disableOrEnableJobs(jobName, item, false);
    }

    private void disableOrEnableJobs(final String jobName, final String item, final boolean disabled) {
        JobNodePath jobNodePath = new JobNodePath(jobName);
        String shardingDisabledNodePath = jobNodePath.getShardingNodePath(item, "disabled");
        if (disabled) {
            regCenter.persist(shardingDisabledNodePath, "");
        } else {
            regCenter.remove(shardingDisabledNodePath);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy