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

org.apache.kylin.rest.cluster.NacosClusterManager Maven / Gradle / Ivy

The newest version!
/*
 * 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.kylin.rest.cluster;

import static org.apache.kylin.common.util.ClusterConstant.COMMON;
import static org.apache.kylin.common.util.ClusterConstant.DATA_LOADING;
import static org.apache.kylin.common.util.ClusterConstant.OPS;
import static org.apache.kylin.common.util.ClusterConstant.QUERY;
import static org.apache.kylin.common.util.ClusterConstant.RESOURCE;
import static org.apache.kylin.common.util.ClusterConstant.SMART;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import javax.annotation.Nonnull;

import org.apache.kylin.common.exception.KylinRuntimeException;
import org.apache.kylin.guava30.shaded.common.base.Preconditions;
import org.apache.kylin.rest.response.ServerInfoResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.cloud.client.serviceregistry.Registration;
import org.springframework.stereotype.Component;

import lombok.extern.slf4j.Slf4j;

@ConditionalOnProperty(value = { "spring.cloud.nacos.discovery.enabled" }, matchIfMissing = true)
@Component
@Slf4j
public class NacosClusterManager implements ClusterManager {

    public static final List SERVER_IDS = Arrays.asList(QUERY, DATA_LOADING, SMART, COMMON, OPS, RESOURCE);

    private final Registration registration;

    @Autowired
    private DiscoveryClient discoveryClient;

    public NacosClusterManager(Registration registration) {
        this.registration = registration;
    }

    @Override
    public String getLocalServer() {
        return registration.getHost() + ":" + registration.getPort();
    }

    @Override
    public List getQueryServers() {
        return getServersByServerId(QUERY);
    }

    @Override
    public List getServersFromCache() {
        return getServers();
    }

    @Override
    public List getJobServers() {
        return getServersByServerId(DATA_LOADING);
    }

    @Override
    public List getServers() {
        List servers = new ArrayList<>();
        for (String serverId : SERVER_IDS) {
            servers.addAll(getServersByServerId(serverId));
        }
        return servers;
    }

    public ServerInfoResponse getServerById(String serverId) {
        List servers = getServersByServerId(serverId);
        if (servers.isEmpty()) {
            return null;
        } else {
            return servers.get(0);
        }
    }

    public List getServersByServerId(String serverId) {
        if (!SERVER_IDS.contains(serverId)) {
            throw new KylinRuntimeException("Unexpected serverId: " + serverId);
        }

        List servers = new ArrayList<>();
        List instances = discoveryClient.getInstances(serverId);
        for (ServiceInstance instance : instances) {
            servers.add(new ServerInfoResponse(instance2ServerStr(instance), serverId));
        }
        return servers;
    }

    private String instance2ServerStr(@Nonnull ServiceInstance serviceInstance) {
        Preconditions.checkNotNull(serviceInstance, "service instance is null");
        return serviceInstance.getHost() + ":" + serviceInstance.getPort();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy