2017-01-10 17:01:12 +08:00
|
|
|
syntax = "proto3";
|
|
|
|
|
2018-05-10 14:11:54 +08:00
|
|
|
package master_pb;
|
2017-01-10 17:01:12 +08:00
|
|
|
|
2020-06-20 23:00:25 +08:00
|
|
|
option go_package = "github.com/chrislusf/seaweedfs/weed/pb/master_pb";
|
|
|
|
|
2017-01-10 17:01:12 +08:00
|
|
|
//////////////////////////////////////////////////
|
|
|
|
|
|
|
|
service Seaweed {
|
2018-06-01 15:39:39 +08:00
|
|
|
rpc SendHeartbeat (stream Heartbeat) returns (stream HeartbeatResponse) {
|
|
|
|
}
|
2019-07-31 16:54:42 +08:00
|
|
|
rpc KeepConnected (stream KeepConnectedRequest) returns (stream VolumeLocation) {
|
2018-07-27 16:54:45 +08:00
|
|
|
}
|
2018-10-14 15:12:28 +08:00
|
|
|
rpc LookupVolume (LookupVolumeRequest) returns (LookupVolumeResponse) {
|
|
|
|
}
|
2018-11-21 03:35:45 +08:00
|
|
|
rpc Assign (AssignRequest) returns (AssignResponse) {
|
|
|
|
}
|
2018-11-23 16:24:51 +08:00
|
|
|
rpc Statistics (StatisticsRequest) returns (StatisticsResponse) {
|
|
|
|
}
|
2019-03-17 04:43:16 +08:00
|
|
|
rpc CollectionList (CollectionListRequest) returns (CollectionListResponse) {
|
|
|
|
}
|
|
|
|
rpc CollectionDelete (CollectionDeleteRequest) returns (CollectionDeleteResponse) {
|
|
|
|
}
|
2019-03-18 11:27:08 +08:00
|
|
|
rpc VolumeList (VolumeListRequest) returns (VolumeListResponse) {
|
|
|
|
}
|
2019-05-28 15:13:13 +08:00
|
|
|
rpc LookupEcVolume (LookupEcVolumeRequest) returns (LookupEcVolumeResponse) {
|
|
|
|
}
|
2019-06-24 06:29:49 +08:00
|
|
|
rpc GetMasterConfiguration (GetMasterConfigurationRequest) returns (GetMasterConfigurationResponse) {
|
|
|
|
}
|
2020-03-02 14:13:47 +08:00
|
|
|
rpc ListMasterClients (ListMasterClientsRequest) returns (ListMasterClientsResponse) {
|
|
|
|
}
|
2020-04-23 16:55:44 +08:00
|
|
|
rpc LeaseAdminToken (LeaseAdminTokenRequest) returns (LeaseAdminTokenResponse) {
|
|
|
|
}
|
|
|
|
rpc ReleaseAdminToken (ReleaseAdminTokenRequest) returns (ReleaseAdminTokenResponse) {
|
|
|
|
}
|
|
|
|
|
2017-01-10 17:01:12 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////
|
|
|
|
|
|
|
|
message Heartbeat {
|
2018-06-01 15:39:39 +08:00
|
|
|
string ip = 1;
|
|
|
|
uint32 port = 2;
|
|
|
|
string public_url = 3;
|
|
|
|
uint32 max_volume_count = 4;
|
|
|
|
uint64 max_file_key = 5;
|
|
|
|
string data_center = 6;
|
|
|
|
string rack = 7;
|
|
|
|
uint32 admin_port = 8;
|
|
|
|
repeated VolumeInformationMessage volumes = 9;
|
2019-04-21 02:35:20 +08:00
|
|
|
// delta volumes
|
|
|
|
repeated VolumeShortInformationMessage new_volumes = 10;
|
|
|
|
repeated VolumeShortInformationMessage deleted_volumes = 11;
|
2019-06-06 04:32:33 +08:00
|
|
|
bool has_no_volumes = 12;
|
2019-05-22 13:41:20 +08:00
|
|
|
|
|
|
|
// erasure coding
|
|
|
|
repeated VolumeEcShardInformationMessage ec_shards = 16;
|
|
|
|
// delta erasure coding shards
|
|
|
|
repeated VolumeEcShardInformationMessage new_ec_shards = 17;
|
|
|
|
repeated VolumeEcShardInformationMessage deleted_ec_shards = 18;
|
2019-06-06 04:32:33 +08:00
|
|
|
bool has_no_ec_shards = 19;
|
2019-05-22 13:41:20 +08:00
|
|
|
|
2017-01-10 17:01:12 +08:00
|
|
|
}
|
2018-06-01 15:39:39 +08:00
|
|
|
|
2017-01-10 17:01:12 +08:00
|
|
|
message HeartbeatResponse {
|
2019-06-18 05:51:47 +08:00
|
|
|
uint64 volume_size_limit = 1;
|
|
|
|
string leader = 2;
|
|
|
|
string metrics_address = 3;
|
|
|
|
uint32 metrics_interval_seconds = 4;
|
2019-11-29 17:05:09 +08:00
|
|
|
repeated StorageBackend storage_backends = 5;
|
2017-01-10 17:01:12 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
message VolumeInformationMessage {
|
2018-06-01 15:39:39 +08:00
|
|
|
uint32 id = 1;
|
|
|
|
uint64 size = 2;
|
|
|
|
string collection = 3;
|
|
|
|
uint64 file_count = 4;
|
|
|
|
uint64 delete_count = 5;
|
|
|
|
uint64 deleted_byte_count = 6;
|
|
|
|
bool read_only = 7;
|
|
|
|
uint32 replica_placement = 8;
|
|
|
|
uint32 version = 9;
|
|
|
|
uint32 ttl = 10;
|
2019-03-19 00:32:21 +08:00
|
|
|
uint32 compact_revision = 11;
|
2019-06-01 14:41:17 +08:00
|
|
|
int64 modified_at_second = 12;
|
2019-12-03 15:23:54 +08:00
|
|
|
string remote_storage_name = 13;
|
|
|
|
string remote_storage_key = 14;
|
2018-06-01 15:39:39 +08:00
|
|
|
}
|
|
|
|
|
2019-04-21 02:35:20 +08:00
|
|
|
message VolumeShortInformationMessage {
|
|
|
|
uint32 id = 1;
|
|
|
|
string collection = 3;
|
|
|
|
uint32 replica_placement = 8;
|
2019-04-21 14:53:37 +08:00
|
|
|
uint32 version = 9;
|
2019-04-21 02:35:20 +08:00
|
|
|
uint32 ttl = 10;
|
|
|
|
}
|
|
|
|
|
2019-05-22 13:41:20 +08:00
|
|
|
message VolumeEcShardInformationMessage {
|
|
|
|
uint32 id = 1;
|
|
|
|
string collection = 2;
|
2019-05-25 04:28:44 +08:00
|
|
|
uint32 ec_index_bits = 3;
|
2019-05-22 13:41:20 +08:00
|
|
|
}
|
|
|
|
|
2019-11-29 17:05:09 +08:00
|
|
|
message StorageBackend {
|
|
|
|
string type = 1;
|
|
|
|
string id = 2;
|
|
|
|
map<string, string> properties = 3;
|
|
|
|
}
|
|
|
|
|
2018-06-01 15:39:39 +08:00
|
|
|
message Empty {
|
2017-01-10 17:01:12 +08:00
|
|
|
}
|
2018-06-25 06:19:57 +08:00
|
|
|
|
|
|
|
message SuperBlockExtra {
|
2018-06-29 13:20:37 +08:00
|
|
|
message ErasureCoding {
|
|
|
|
uint32 data = 1;
|
|
|
|
uint32 parity = 2;
|
|
|
|
repeated uint32 volume_ids = 3;
|
|
|
|
}
|
|
|
|
ErasureCoding erasure_coding = 1;
|
2018-06-25 06:19:57 +08:00
|
|
|
}
|
2018-07-27 16:54:45 +08:00
|
|
|
|
2019-07-31 16:54:42 +08:00
|
|
|
message KeepConnectedRequest {
|
2018-07-28 14:09:55 +08:00
|
|
|
string name = 1;
|
2020-03-02 14:13:47 +08:00
|
|
|
uint32 grpc_port = 2;
|
2018-07-28 14:09:55 +08:00
|
|
|
}
|
|
|
|
|
2018-07-27 16:54:45 +08:00
|
|
|
message VolumeLocation {
|
|
|
|
string url = 1;
|
|
|
|
string public_url = 2;
|
2018-07-28 14:09:55 +08:00
|
|
|
repeated uint32 new_vids = 3;
|
|
|
|
repeated uint32 deleted_vids = 4;
|
2019-07-31 16:54:42 +08:00
|
|
|
string leader = 5; // optional when leader is not itself
|
2020-11-12 07:10:06 +08:00
|
|
|
string data_center = 6; // optional when DataCenter is in use
|
2018-07-27 16:54:45 +08:00
|
|
|
}
|
2018-10-14 15:12:28 +08:00
|
|
|
|
|
|
|
message LookupVolumeRequest {
|
|
|
|
repeated string volume_ids = 1;
|
|
|
|
string collection = 2; // optional, a bit faster if provided.
|
|
|
|
}
|
|
|
|
message LookupVolumeResponse {
|
|
|
|
message VolumeIdLocation {
|
|
|
|
string volume_id = 1;
|
|
|
|
repeated Location locations = 2;
|
|
|
|
string error = 3;
|
|
|
|
}
|
|
|
|
repeated VolumeIdLocation volume_id_locations = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message Location {
|
|
|
|
string url = 1;
|
|
|
|
string public_url = 2;
|
|
|
|
}
|
2018-11-21 03:35:45 +08:00
|
|
|
|
|
|
|
message AssignRequest {
|
|
|
|
uint64 count = 1;
|
|
|
|
string replication = 2;
|
|
|
|
string collection = 3;
|
|
|
|
string ttl = 4;
|
|
|
|
string data_center = 5;
|
|
|
|
string rack = 6;
|
|
|
|
string data_node = 7;
|
2019-10-22 13:57:01 +08:00
|
|
|
uint32 memory_map_max_size_mb = 8;
|
2019-11-11 04:05:45 +08:00
|
|
|
uint32 Writable_volume_count = 9;
|
2018-11-21 03:35:45 +08:00
|
|
|
}
|
|
|
|
message AssignResponse {
|
|
|
|
string fid = 1;
|
|
|
|
string url = 2;
|
|
|
|
string public_url = 3;
|
|
|
|
uint64 count = 4;
|
|
|
|
string error = 5;
|
2019-02-15 16:09:19 +08:00
|
|
|
string auth = 6;
|
2018-11-21 03:35:45 +08:00
|
|
|
}
|
2018-11-23 16:24:51 +08:00
|
|
|
|
|
|
|
message StatisticsRequest {
|
|
|
|
string replication = 1;
|
|
|
|
string collection = 2;
|
|
|
|
string ttl = 3;
|
|
|
|
}
|
|
|
|
message StatisticsResponse {
|
|
|
|
string replication = 1;
|
|
|
|
string collection = 2;
|
|
|
|
string ttl = 3;
|
|
|
|
uint64 total_size = 4;
|
|
|
|
uint64 used_size = 5;
|
|
|
|
uint64 file_count = 6;
|
|
|
|
}
|
2019-03-17 04:43:16 +08:00
|
|
|
|
|
|
|
//
|
|
|
|
// collection related
|
|
|
|
//
|
|
|
|
message Collection {
|
|
|
|
string name = 1;
|
|
|
|
}
|
|
|
|
message CollectionListRequest {
|
2019-05-31 00:27:23 +08:00
|
|
|
bool include_normal_volumes = 1;
|
|
|
|
bool include_ec_volumes = 2;
|
2019-03-17 04:43:16 +08:00
|
|
|
}
|
|
|
|
message CollectionListResponse {
|
|
|
|
repeated Collection collections = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message CollectionDeleteRequest {
|
|
|
|
string name = 1;
|
|
|
|
}
|
|
|
|
message CollectionDeleteResponse {
|
|
|
|
}
|
2019-03-18 11:27:08 +08:00
|
|
|
|
|
|
|
//
|
|
|
|
// volume related
|
|
|
|
//
|
|
|
|
message DataNodeInfo {
|
|
|
|
string id = 1;
|
|
|
|
uint64 volume_count = 2;
|
|
|
|
uint64 max_volume_count = 3;
|
|
|
|
uint64 free_volume_count = 4;
|
|
|
|
uint64 active_volume_count = 5;
|
|
|
|
repeated VolumeInformationMessage volume_infos = 6;
|
2019-05-23 13:44:28 +08:00
|
|
|
repeated VolumeEcShardInformationMessage ec_shard_infos = 7;
|
2019-12-04 13:36:42 +08:00
|
|
|
uint64 remote_volume_count = 8;
|
2019-03-18 11:27:08 +08:00
|
|
|
}
|
|
|
|
message RackInfo {
|
|
|
|
string id = 1;
|
|
|
|
uint64 volume_count = 2;
|
|
|
|
uint64 max_volume_count = 3;
|
|
|
|
uint64 free_volume_count = 4;
|
|
|
|
uint64 active_volume_count = 5;
|
|
|
|
repeated DataNodeInfo data_node_infos = 6;
|
2019-12-04 13:36:42 +08:00
|
|
|
uint64 remote_volume_count = 7;
|
2019-03-18 11:27:08 +08:00
|
|
|
}
|
|
|
|
message DataCenterInfo {
|
|
|
|
string id = 1;
|
|
|
|
uint64 volume_count = 2;
|
|
|
|
uint64 max_volume_count = 3;
|
|
|
|
uint64 free_volume_count = 4;
|
|
|
|
uint64 active_volume_count = 5;
|
|
|
|
repeated RackInfo rack_infos = 6;
|
2019-12-04 13:36:42 +08:00
|
|
|
uint64 remote_volume_count = 7;
|
2019-03-18 11:27:08 +08:00
|
|
|
}
|
|
|
|
message TopologyInfo {
|
|
|
|
string id = 1;
|
|
|
|
uint64 volume_count = 2;
|
|
|
|
uint64 max_volume_count = 3;
|
|
|
|
uint64 free_volume_count = 4;
|
|
|
|
uint64 active_volume_count = 5;
|
|
|
|
repeated DataCenterInfo data_center_infos = 6;
|
2019-12-04 13:36:42 +08:00
|
|
|
uint64 remote_volume_count = 7;
|
2019-03-18 11:27:08 +08:00
|
|
|
}
|
|
|
|
message VolumeListRequest {
|
|
|
|
}
|
|
|
|
message VolumeListResponse {
|
|
|
|
TopologyInfo topology_info = 1;
|
2019-05-06 12:17:23 +08:00
|
|
|
uint64 volume_size_limit_mb = 2;
|
2019-03-18 11:27:08 +08:00
|
|
|
}
|
2019-05-28 15:13:13 +08:00
|
|
|
|
|
|
|
message LookupEcVolumeRequest {
|
|
|
|
uint32 volume_id = 1;
|
|
|
|
}
|
|
|
|
message LookupEcVolumeResponse {
|
|
|
|
uint32 volume_id = 1;
|
|
|
|
message EcShardIdLocation {
|
|
|
|
uint32 shard_id = 1;
|
|
|
|
repeated Location locations = 2;
|
|
|
|
}
|
|
|
|
repeated EcShardIdLocation shard_id_locations = 2;
|
|
|
|
}
|
2019-06-24 06:29:49 +08:00
|
|
|
|
|
|
|
message GetMasterConfigurationRequest {
|
|
|
|
}
|
|
|
|
message GetMasterConfigurationResponse {
|
|
|
|
string metrics_address = 1;
|
|
|
|
uint32 metrics_interval_seconds = 2;
|
2020-09-16 16:12:22 +08:00
|
|
|
repeated StorageBackend storage_backends = 3;
|
2020-10-01 00:15:55 +08:00
|
|
|
string default_replication = 4;
|
2020-10-07 16:25:39 +08:00
|
|
|
string leader = 5;
|
2019-06-24 06:29:49 +08:00
|
|
|
}
|
2020-03-02 14:13:47 +08:00
|
|
|
|
|
|
|
message ListMasterClientsRequest {
|
|
|
|
string client_type = 1;
|
|
|
|
}
|
|
|
|
message ListMasterClientsResponse {
|
|
|
|
repeated string grpc_addresses = 1;
|
|
|
|
}
|
2020-04-23 16:55:44 +08:00
|
|
|
|
|
|
|
message LeaseAdminTokenRequest {
|
|
|
|
int64 previous_token = 1;
|
|
|
|
int64 previous_lock_time = 2;
|
2020-05-26 09:39:53 +08:00
|
|
|
string lock_name = 3;
|
2020-04-23 16:55:44 +08:00
|
|
|
}
|
|
|
|
message LeaseAdminTokenResponse {
|
2020-04-23 17:31:04 +08:00
|
|
|
int64 token = 1;
|
|
|
|
int64 lock_ts_ns = 2;
|
2020-04-23 16:55:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
message ReleaseAdminTokenRequest {
|
|
|
|
int64 previous_token = 1;
|
|
|
|
int64 previous_lock_time = 2;
|
2020-05-26 09:39:53 +08:00
|
|
|
string lock_name = 3;
|
2020-04-23 16:55:44 +08:00
|
|
|
}
|
|
|
|
message ReleaseAdminTokenResponse {
|
|
|
|
}
|