HDFS-11127. Block Storage : add block storage service protocol. Contributed by Chen Liang
This commit is contained in:
parent
7b761f18de
commit
e6a6b5b729
|
@ -354,6 +354,7 @@ http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<include>fsimage.proto</include>
|
<include>fsimage.proto</include>
|
||||||
<include>StorageContainerLocationProtocol.proto</include>
|
<include>StorageContainerLocationProtocol.proto</include>
|
||||||
<include>StorageContainerDatanodeProtocol.proto</include>
|
<include>StorageContainerDatanodeProtocol.proto</include>
|
||||||
|
<include>CBlockServiceProtocol.proto</include>
|
||||||
</includes>
|
</includes>
|
||||||
</source>
|
</source>
|
||||||
<output>${project.build.directory}/generated-sources/java</output>
|
<output>${project.build.directory}/generated-sources/java</output>
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
/**
|
||||||
|
* 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.cblock.protocol.proto";
|
||||||
|
option java_outer_classname = "CBlockServiceProtocolProtos";
|
||||||
|
option java_generic_services = true;
|
||||||
|
option java_generate_equals_and_hash = true;
|
||||||
|
package hadoop.cblock;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent to CBlock server to create a volume. Creating
|
||||||
|
* volume requries four parameters: owner of the volume, name of the volume
|
||||||
|
* size of volume and block size of the volume.
|
||||||
|
*/
|
||||||
|
message CreateVolumeRequestProto {
|
||||||
|
required string userName = 1;
|
||||||
|
required string volumeName = 2;
|
||||||
|
required uint64 volumeSize = 3;
|
||||||
|
optional uint32 blockSize = 4 [default = 4096];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Empty response message.
|
||||||
|
*/
|
||||||
|
message CreateVolumeResponseProto {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent to CBlock server to delete a volume. The volume
|
||||||
|
* is specified by owner name and volume name. If force is set to
|
||||||
|
* false, volume will be deleted only if it is empty. Otherwise delete it
|
||||||
|
* regardless.
|
||||||
|
*/
|
||||||
|
message DeleteVolumeRequestProto {
|
||||||
|
required string userName = 1;
|
||||||
|
required string volumeName = 2;
|
||||||
|
optional bool force = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Empty response message.
|
||||||
|
*/
|
||||||
|
message DeleteVolumeResponseProto {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent to CBlock server to request info of a volume. The
|
||||||
|
* volume is specified by owner name and volume name.
|
||||||
|
*/
|
||||||
|
message InfoVolumeRequestProto {
|
||||||
|
required string userName = 1;
|
||||||
|
required string volumeName = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message describes the information of a volume.
|
||||||
|
* Currently, the info includes the volume creation parameters and a number
|
||||||
|
* as the usage of the volume, in terms of number of bytes.
|
||||||
|
*/
|
||||||
|
message VolumeInfoProto {
|
||||||
|
required string userName = 1;
|
||||||
|
required string volumeName = 2;
|
||||||
|
required uint64 volumeSize = 3;
|
||||||
|
required uint64 blockSize = 4;
|
||||||
|
optional uint64 usage = 5;
|
||||||
|
// TODO : potentially volume ACL
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent from CBlock server as response of info volume request.
|
||||||
|
*/
|
||||||
|
message InfoVolumeResponseProto {
|
||||||
|
optional VolumeInfoProto volumeInfo = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent to CBlock server to list all available volume.
|
||||||
|
*/
|
||||||
|
message ListVolumeRequestProto {
|
||||||
|
optional string userName = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This message is sent from CBlock server as response of volume listing.
|
||||||
|
*/
|
||||||
|
message ListVolumeResponseProto {
|
||||||
|
repeated VolumeInfoProto volumeEntry = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
service CBlockServiceProtocolService {
|
||||||
|
/**
|
||||||
|
* Create a volume.
|
||||||
|
*/
|
||||||
|
rpc createVolume(CreateVolumeRequestProto) returns(CreateVolumeResponseProto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete a volume.
|
||||||
|
*/
|
||||||
|
rpc deleteVolume(DeleteVolumeRequestProto) returns(DeleteVolumeResponseProto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get info of a volume.
|
||||||
|
*/
|
||||||
|
rpc infoVolume(InfoVolumeRequestProto) returns(InfoVolumeResponseProto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List all available volumes.
|
||||||
|
*/
|
||||||
|
rpc listVolume(ListVolumeRequestProto) returns(ListVolumeResponseProto);
|
||||||
|
}
|
Loading…
Reference in New Issue