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

org.apache.hadoop.hbase.rsgroup.RSGroupAdmin Maven / Gradle / Ivy

There is a newer version: 2.6.0-hadoop3
Show 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.hadoop.hbase.rsgroup;

import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.BalanceRequest;
import org.apache.hadoop.hbase.client.BalanceResponse;
import org.apache.hadoop.hbase.net.Address;
import org.apache.yetus.audience.InterfaceAudience;

/**
 * Group user API interface used between client and server.
 */
@InterfaceAudience.Private
public interface RSGroupAdmin {
  /**
   * Gets {@code RSGroupInfo} for given group name.
   */
  RSGroupInfo getRSGroupInfo(String groupName) throws IOException;

  /**
   * Gets {@code RSGroupInfo} for the given table's group.
   */
  RSGroupInfo getRSGroupInfoOfTable(TableName tableName) throws IOException;

  /**
   * Move given set of servers to the specified target RegionServer group.
   */
  void moveServers(Set
servers, String targetGroup) throws IOException; /** * Move given set of tables to the specified target RegionServer group. This will unassign all of * a table's region so it can be reassigned to the correct group. */ void moveTables(Set tables, String targetGroup) throws IOException; /** * Creates a new RegionServer group with the given name. */ void addRSGroup(String groupName) throws IOException; /** * Removes RegionServer group associated with the given name. */ void removeRSGroup(String groupName) throws IOException; /** * Balance regions in the given RegionServer group. * @return boolean Whether balance ran or not */ default BalanceResponse balanceRSGroup(String groupName) throws IOException { return balanceRSGroup(groupName, BalanceRequest.defaultInstance()); } /** * Balance regions in the given RegionServer group, running based on the given * {@link BalanceRequest}. * @return boolean Whether balance ran or not */ BalanceResponse balanceRSGroup(String groupName, BalanceRequest request) throws IOException; /** * Lists current set of RegionServer groups. */ List listRSGroups() throws IOException; /** * Retrieve the RSGroupInfo a server is affiliated to * @param hostPort HostPort to get RSGroupInfo for */ RSGroupInfo getRSGroupOfServer(Address hostPort) throws IOException; /** * Move given set of servers and tables to the specified target RegionServer group. * @param servers set of servers to move * @param tables set of tables to move * @param targetGroup the target group name * @throws IOException if moving the server and tables fail */ void moveServersAndTables(Set
servers, Set tables, String targetGroup) throws IOException; /** * Remove decommissioned servers from rsgroup. 1. Sometimes we may find the server aborted due to * some hardware failure and we must offline the server for repairing. Or we need to move some * servers to join other clusters. So we need to remove these servers from the rsgroup. 2. * Dead/recovering/live servers will be disallowed. * @param servers set of servers to remove */ void removeServers(Set
servers) throws IOException; /** * Rename rsgroup. * @param oldName old rsgroup name * @param newName new rsgroup name */ void renameRSGroup(String oldName, String newName) throws IOException; /** * Update RSGroup configuration * @param groupName the group name * @param configuration new configuration of the group name to be set * @throws IOException if a remote or network exception occurs */ void updateRSGroupConfig(String groupName, Map configuration) throws IOException; /** * Update the configuration and trigger an online config change on all the regionservers in the * RSGroup. * @param groupName the group name * @throws IOException if a remote or network exception occurs */ void updateConfiguration(String groupName) throws IOException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy