/* * DataDistributorInterface.h * * This source file is part of the FoundationDB open source project * * Copyright 2013-2019 Apple Inc. and the FoundationDB project authors * * Licensed 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. */ #ifndef FDBSERVER_DATADISTRIBUTORINTERFACE_H #define FDBSERVER_DATADISTRIBUTORINTERFACE_H #include "fdbrpc/fdbrpc.h" #include "fdbrpc/Locality.h" #include "fdbclient/FDBTypes.h" struct DataDistributorInterface { constexpr static FileIdentifier file_identifier = 12383874; RequestStream> waitFailure; RequestStream haltDataDistributor; struct LocalityData locality; RequestStream distributorSnapReq; RequestStream distributorExclCheckReq; RequestStream dataDistributorMetrics; DataDistributorInterface() {} explicit DataDistributorInterface(const struct LocalityData& l) : locality(l) {} void initEndpoints() {} UID id() const { return waitFailure.getEndpoint().token; } NetworkAddress address() const { return waitFailure.getEndpoint().getPrimaryAddress(); } bool operator== (const DataDistributorInterface& r) const { return id() == r.id(); } bool operator!= (const DataDistributorInterface& r) const { return !(*this == r); } template void serialize(Archive& ar) { serializer(ar, waitFailure, haltDataDistributor, locality, distributorSnapReq, distributorExclCheckReq, dataDistributorMetrics); } }; struct HaltDataDistributorRequest { constexpr static FileIdentifier file_identifier = 1904127; UID requesterID; ReplyPromise reply; HaltDataDistributorRequest() {} explicit HaltDataDistributorRequest(UID uid) : requesterID(uid) {} template void serialize(Ar& ar) { serializer(ar, requesterID, reply); } }; struct GetDataDistributorMetricsReply { constexpr static FileIdentifier file_identifier = 1284337; Standalone> storageMetricsList; Optional midShardSize; GetDataDistributorMetricsReply() {} template void serialize(Ar& ar) { serializer(ar, storageMetricsList, midShardSize); } }; struct GetDataDistributorMetricsRequest { constexpr static FileIdentifier file_identifier = 1059267; KeyRange keys; int shardLimit; ReplyPromise reply; bool midOnly = false; GetDataDistributorMetricsRequest() {} explicit GetDataDistributorMetricsRequest(KeyRange const& keys, const int shardLimit, bool midOnly = false) : keys(keys), shardLimit(shardLimit), midOnly(midOnly) {} template void serialize(Ar& ar) { serializer(ar, keys, shardLimit, reply, midOnly); } }; struct DistributorSnapRequest { constexpr static FileIdentifier file_identifier = 5427684; Arena arena; StringRef snapPayload; UID snapUID; ReplyPromise reply; Optional debugID; explicit DistributorSnapRequest(Optional const& debugID = Optional()) : debugID(debugID) {} explicit DistributorSnapRequest(StringRef snap, UID snapUID, Optional debugID = Optional()) : snapPayload(snap), snapUID(snapUID), debugID(debugID) {} template void serialize(Ar& ar) { serializer(ar, snapPayload, snapUID, reply, arena, debugID); } }; struct DistributorExclusionSafetyCheckReply { constexpr static FileIdentifier file_identifier = 13005960; bool safe; DistributorExclusionSafetyCheckReply() : safe(false) {} explicit DistributorExclusionSafetyCheckReply(bool safe) : safe(safe) {} template void serialize(Ar& ar) { serializer(ar, safe); } }; struct DistributorExclusionSafetyCheckRequest { constexpr static FileIdentifier file_identifier = 5830931; vector exclusions; ReplyPromise reply; DistributorExclusionSafetyCheckRequest() {} explicit DistributorExclusionSafetyCheckRequest(vector exclusions) : exclusions(exclusions) {} template void serialize(Ar& ar) { serializer(ar, exclusions, reply); } }; #endif //FDBSERVER_DATADISTRIBUTORINTERFACE_H