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

com.alipay.sofa.jraft.rhea.MetadataStore 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 com.alipay.sofa.jraft.rhea;

import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.CompletableFuture;

import com.alipay.sofa.jraft.rhea.metadata.Cluster;
import com.alipay.sofa.jraft.rhea.metadata.Region;
import com.alipay.sofa.jraft.rhea.metadata.RegionStats;
import com.alipay.sofa.jraft.rhea.metadata.Store;
import com.alipay.sofa.jraft.rhea.metadata.StoreStats;
import com.alipay.sofa.jraft.rhea.util.Pair;
import com.alipay.sofa.jraft.util.Endpoint;

/**
 *
 * @author jiachun.fjc
 */
public interface MetadataStore {

    /**
     * Returns the specified cluster information.
     */
    Cluster getClusterInfo(final long clusterId);

    /**
     * The pd server stores the storeIds of all nodes.
     * This method provides a lookup for the storeId according
     * to the endpoint.  If there is no value, then a globally
     * unique storeId is created.
     */
    Long getOrCreateStoreId(final long clusterId, final Endpoint endpoint);

    /**
     * Query the store information by the storeId.  If the result
     * is a empty instance, the caller needs to use its own local
     * configuration.
     */
    Store getStoreInfo(final long clusterId, final long storeId);

    /**
     * Query the store information by the endpoint.  If the result
     * is a empty instance, the caller needs to use its own local
     * configuration.
     */
    Store getStoreInfo(final long clusterId, final Endpoint endpoint);

    /**
     * Update the store information by the storeId, and return the
     * previous value.
     */
    CompletableFuture updateStoreInfo(final long clusterId, final Store store);

    /**
     * Create a globally unique regionId.
     */
    Long createRegionId(final long clusterId);

    /**
     * Returns the stats information of the specified store.
     */
    StoreStats getStoreStats(final long clusterId, final long storeId);

    /**
     * Update the stats information of the specified store.
     */
    CompletableFuture updateStoreStats(final long clusterId, final StoreStats storeStats);

    /**
     * Returns the stats information of the specified region.
     */
    Pair getRegionStats(final long clusterId, final Region region);

    /**
     * Update the stats information of the specified region.
     */
    CompletableFuture updateRegionStats(final long clusterId, final Region region,
                                                 final RegionStats regionStats);

    /**
     * Batch update the stats information of regions.
     */
    CompletableFuture batchUpdateRegionStats(final long clusterId,
                                                      final List> regionStatsList);

    Set unsafeGetStoreIds(final long clusterId);

    Map unsafeGetStoreIdsByEndpoints(final long clusterId, final List endpoints);

    /**
     * Clear the cache.
     */
    void invalidCache();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy