consistent_hash_selector.h 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * Copyright [2021] JD.com, Inc.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #ifndef CONSISTENT_HASH_SELECTOR_H__
  17. #define CONSISTENT_HASH_SELECTOR_H__
  18. #include <stdint.h>
  19. #include <map>
  20. #include <string>
  21. #include <vector>
  22. #include "algorithm/chash.h"
  23. class ConsistentHashSelector {
  24. public:
  25. uint32_t Hash(const char *key, int len)
  26. {
  27. return chash(key, len);
  28. }
  29. const std::string &Select(uint32_t hash);
  30. const std::string &Select(const char *key, int len)
  31. {
  32. return Select(Hash(key, len));
  33. }
  34. static const int VIRTUAL_NODE_COUNT = 100;
  35. void add_node(const char *name);
  36. void Clear()
  37. {
  38. m_nodes.clear();
  39. m_nodeNames.clear();
  40. }
  41. private:
  42. std::map<uint32_t, int> m_nodes;
  43. std::vector<std::string> m_nodeNames;
  44. };
  45. #endif