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

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

package com.cloud.task.impl;

import java.util.*;
import java.util.concurrent.ConcurrentHashMap;

import com.cloud.task.api.IServerStatisticsService;
import com.cloud.task.model.ServerBriefInfo;
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 ServerStatisticsServiceImpl implements IServerStatisticsService {

    @Autowired
    private CoordinatorRegistryCenter regCenter;

    @Override
    public int getServersTotalCount() {
        Set servers = new HashSet<>();
        for (String jobName : regCenter.getChildrenKeys("/")) {
            JobNodePath jobNodePath = new JobNodePath(jobName);
            for (String each : regCenter.getChildrenKeys(jobNodePath.getServerNodePath())) {
                servers.add(each);
            }
        }
        return servers.size();
    }

    @Override
    public Collection getAllServersBriefInfo() {
        ConcurrentHashMap servers = new ConcurrentHashMap<>();
        for (String jobName : regCenter.getChildrenKeys("/")) {
            JobNodePath jobNodePath = new JobNodePath(jobName);
            for (String each : regCenter.getChildrenKeys(jobNodePath.getServerNodePath())) {
                servers.putIfAbsent(each, new ServerBriefInfo(each));
                ServerBriefInfo serverInfo = servers.get(each);
                if ("DISABLED".equalsIgnoreCase(regCenter.get(jobNodePath.getServerNodePath(each)))) {
                    serverInfo.getDisabledJobsNum().incrementAndGet();
                }
                serverInfo.getJobNames().add(jobName);
                serverInfo.setJobsNum(serverInfo.getJobNames().size());
            }
            List instances = regCenter.getChildrenKeys(jobNodePath.getInstancesNodePath());
            for (String each : instances) {
                String serverIp = each.split("@-@")[0];
                ServerBriefInfo serverInfo = servers.get(serverIp);
                if (null != serverInfo) {
                    serverInfo.getInstances().add(each);
                    serverInfo.setInstancesNum(serverInfo.getInstances().size());
                }
            }
        }
        List result = new ArrayList<>(servers.values());
        Collections.sort(result);
        return result;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy