/** * 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. */ /** * These .proto interfaces are private and unstable. * Please see http://wiki.apache.org/hadoop/Compatibility * for what changes are allowed for a *unstable* .proto interface. */ option java_package = "org.apache.hadoop.ozone.protocol.proto"; option java_outer_classname = "OzoneProtos"; option java_generic_services = true; option java_generate_equals_and_hash = true; package hadoop.hdfs.ozone; import "hdfs.proto"; // A pipeline is composed of one or more datanodes that back a container. message Pipeline { required string leaderID = 1; repeated DatanodeIDProto members = 2; required string containerName = 3; optional LifeCycleState state = 4 [default = OPEN]; } message KeyValue { required string key = 1; optional string value = 2; } /** * Enum that represents the Node State. This is used in calls to getNodeList * and getNodeCount. */ enum NodeState { HEALTHY = 1; STALE = 2; DEAD = 3; DECOMMISSIONING = 4; DECOMMISSIONED = 5; RAFT_MEMBER = 6; FREE_NODE = 7; // Not a member in raft. UNKNOWN = 8; } enum QueryScope { CLUSTER = 1; POOL = 2; } message Node { required DatanodeIDProto nodeID = 1; repeated NodeState nodeStates = 2; } message NodePool { repeated Node nodes = 1; } /** * LifeCycleState for SCM object creation state machine: * ->Allocated: allocated on SCM but clean has not started creating it yet. * ->Creating: allocated and assigned to client to create but not ack-ed yet. * ->Open: allocated on SCM and created on datanodes and ack-ed by a client. * ->Close: container closed due to space all used or error? * ->Timeout -> container failed to create on datanodes or ack-ed by client. * ->Deleting(TBD) -> container will be deleted after timeout * 1. ALLOCATE-ed containers on SCM can't serve key/block related operation * until ACK-ed explicitly which changes the state to OPEN. * 2. Only OPEN/CLOSED containers can serve key/block related operation. * 3. ALLOCATE-ed containers that are not ACK-ed timely will be TIMEOUT and * CLEANUP asynchronously. */ enum LifeCycleState { ALLOCATED = 1; CREATING = 2; // Used for container allocated/created by different client. OPEN =3; // Mostly an update to SCM via HB or client call. CLOSED = 4; // !!State after this has not been used yet. DELETING = 5; DELETED = 6; // object is deleted. } enum LifeCycleEvent { BEGIN_CREATE = 1; // A request to client to create this object COMPLETE_CREATE = 2; CLOSE = 3; // !!Event after this has not been used yet. UPDATE = 4; TIMEOUT = 5; // creation has timed out from SCM's View. DELETE = 6; CLEANUP = 7; } message SCMContainerInfo { required LifeCycleState state = 1; required Pipeline pipeline = 2; optional int64 stateEnterTime = 3; } enum ReplicationType { RATIS = 1; STAND_ALONE = 2; CHAINED = 3; } enum ReplicationFactor { ONE = 1; THREE = 3; }