ase.hbase-protocol-shaded.2.6.0.source-code.RegionServerStatus.proto Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hbase-protocol-shaded
Show all versions of hbase-protocol-shaded
Shaded protobuf protocol classes used by HBase internally.
/**
* 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.
*/
syntax = "proto2";
// This file contains protocol buffers that are used for RegionServerStatusProtocol.
package hbase.pb;
option java_package = "org.apache.hadoop.hbase.shaded.protobuf.generated";
option java_outer_classname = "RegionServerStatusProtos";
option java_generic_services = true;
option java_generate_equals_and_hash = true;
option optimize_for = SPEED;
import "HBase.proto";
import "ClusterStatus.proto";
import "ErrorHandling.proto";
message RegionServerStartupRequest {
/** Port number this regionserver is up on */
required uint32 port = 1;
/** This servers' startcode */
required uint64 server_start_code = 2;
/** Current time of the region server in ms */
required uint64 server_current_time = 3;
/** hostname for region server, optional */
optional string use_this_hostname_instead = 4;
}
message RegionServerStartupResponse {
/**
* Configuration for the regionserver to use: e.g. filesystem,
* hbase rootdir, the hostname to use creating the RegionServer ServerName,
* etc
*/
repeated NameStringPair map_entries = 1;
}
message RegionServerReportRequest {
required ServerName server = 1;
/** load the server is under */
optional ServerLoad load = 2;
}
message RegionServerReportResponse {
}
message ReportRSFatalErrorRequest {
/** name of the server experiencing the error */
required ServerName server = 1;
/** informative text to expose in the master logs and UI */
required string error_message = 2;
}
message ReportRSFatalErrorResponse {
}
message GetLastFlushedSequenceIdRequest {
/** region name */
required bytes region_name = 1;
}
message GetLastFlushedSequenceIdResponse {
/** the last WAL sequence id flushed from MemStore to HFile for the region */
required uint64 last_flushed_sequence_id = 1;
/** the last WAL sequence id flushed from MemStore to HFile for stores of the region */
repeated StoreSequenceId store_last_flushed_sequence_id = 2;
}
message RegionStateTransition {
required TransitionCode transition_code = 1;
/** Mutliple regions are involved during merging/splitting */
repeated RegionInfo region_info = 2;
/** For newly opened region, the open seq num is needed */
optional uint64 open_seq_num = 3;
repeated int64 proc_id = 4;
enum TransitionCode {
OPENED = 0;
FAILED_OPEN = 1;
/** No failed_close, in which case region server will abort */
CLOSED = 2;
/** Ask master for ok to split/merge region(s) */
READY_TO_SPLIT = 3;
READY_TO_MERGE = 4;
/** We used to have PONR enums for split and merge in here occupying
positions 5 and 6 but they have since been removed. Do not reuse these
indices */
SPLIT = 7;
MERGED = 8;
SPLIT_REVERTED = 9;
MERGE_REVERTED = 10;
}
}
message ReportRegionStateTransitionRequest {
/** This region server's server name */
required ServerName server = 1;
repeated RegionStateTransition transition = 2;
}
message ReportRegionStateTransitionResponse {
/** Error message if failed to update the region state */
optional string error_message = 1;
}
message RegionSpaceUse {
optional RegionInfo region_info = 1; // A region identifier
optional uint64 region_size = 2; // The size in bytes of the region
}
/**
* Reports filesystem usage for regions.
*/
message RegionSpaceUseReportRequest {
repeated RegionSpaceUse space_use = 1;
}
message RegionSpaceUseReportResponse {
}
message RemoteProcedureResult {
required uint64 proc_id = 1;
enum Status {
SUCCESS = 1;
ERROR = 2;
}
required Status status = 2;
optional ForeignExceptionMessage error = 3;
}
message ReportProcedureDoneRequest {
repeated RemoteProcedureResult result = 1;
}
message ReportProcedureDoneResponse {
}
message FileArchiveNotificationRequest {
message FileWithSize {
optional TableName table_name = 1;
optional string name = 2;
optional uint64 size = 3;
}
repeated FileWithSize archived_files = 1;
}
message FileArchiveNotificationResponse {
}
message GetLiveRegionServersRequest {
required uint32 count = 1;
}
message GetLiveRegionServersResponse {
repeated ServerName server = 1;
required uint32 total = 2;
}
service RegionServerStatusService {
/** Called when a region server first starts. */
rpc RegionServerStartup(RegionServerStartupRequest)
returns(RegionServerStartupResponse);
/** Called to report the load the RegionServer is under. */
rpc RegionServerReport(RegionServerReportRequest)
returns(RegionServerReportResponse);
/**
* Called by a region server to report a fatal error that is causing it to
* abort.
*/
rpc ReportRSFatalError(ReportRSFatalErrorRequest)
returns(ReportRSFatalErrorResponse);
/** Called to get the sequence id of the last MemStore entry flushed to an
* HFile for a specified region. Used by the region server to speed up
* log splitting. */
rpc GetLastFlushedSequenceId(GetLastFlushedSequenceIdRequest)
returns(GetLastFlushedSequenceIdResponse);
/**
* Called by a region server to report the progress of a region
* transition. If the request fails, the transition should
* be aborted.
*/
rpc ReportRegionStateTransition(ReportRegionStateTransitionRequest)
returns(ReportRegionStateTransitionResponse);
/**
* Reports Region filesystem space use
*/
rpc ReportRegionSpaceUse(RegionSpaceUseReportRequest)
returns(RegionSpaceUseReportResponse);
rpc ReportProcedureDone(ReportProcedureDoneRequest)
returns(ReportProcedureDoneResponse);
/** Reports files that were moved to the archive directory for space quotas */
rpc ReportFileArchival(FileArchiveNotificationRequest)
returns(FileArchiveNotificationResponse);
/** Get some live region servers to be used as seed for bootstrap nodes */
rpc GetLiveRegionServers(GetLiveRegionServersRequest)
returns(GetLiveRegionServersResponse);
}