metric.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. #ifndef DBENGINE_METRIC_H
  3. #define DBENGINE_METRIC_H
  4. #include "../rrd.h"
  5. #define MRG_CACHE_LINE_PADDING(x) uint8_t padding##x[64]
  6. typedef struct metric METRIC;
  7. typedef struct mrg MRG;
  8. typedef struct mrg_entry {
  9. uuid_t *uuid;
  10. Word_t section;
  11. time_t first_time_s;
  12. time_t last_time_s;
  13. uint32_t latest_update_every_s;
  14. } MRG_ENTRY;
  15. struct mrg_statistics {
  16. // --- non-atomic --- under a write lock
  17. size_t entries;
  18. size_t size; // total memory used, with indexing
  19. size_t additions;
  20. size_t additions_duplicate;
  21. size_t deletions;
  22. size_t delete_having_retention_or_referenced;
  23. size_t delete_misses;
  24. MRG_CACHE_LINE_PADDING(0);
  25. // --- atomic --- multiple readers / writers
  26. size_t entries_referenced;
  27. MRG_CACHE_LINE_PADDING(2);
  28. size_t current_references;
  29. MRG_CACHE_LINE_PADDING(3);
  30. size_t search_hits;
  31. size_t search_misses;
  32. MRG_CACHE_LINE_PADDING(4);
  33. size_t writers;
  34. size_t writers_conflicts;
  35. };
  36. MRG *mrg_create(ssize_t partitions);
  37. void mrg_destroy(MRG *mrg);
  38. METRIC *mrg_metric_dup(MRG *mrg, METRIC *metric);
  39. bool mrg_metric_release(MRG *mrg, METRIC *metric);
  40. METRIC *mrg_metric_add_and_acquire(MRG *mrg, MRG_ENTRY entry, bool *ret);
  41. METRIC *mrg_metric_get_and_acquire(MRG *mrg, uuid_t *uuid, Word_t section);
  42. bool mrg_metric_release_and_delete(MRG *mrg, METRIC *metric);
  43. Word_t mrg_metric_id(MRG *mrg, METRIC *metric);
  44. uuid_t *mrg_metric_uuid(MRG *mrg, METRIC *metric);
  45. Word_t mrg_metric_section(MRG *mrg, METRIC *metric);
  46. bool mrg_metric_set_first_time_s(MRG *mrg, METRIC *metric, time_t first_time_s);
  47. bool mrg_metric_set_first_time_s_if_bigger(MRG *mrg, METRIC *metric, time_t first_time_s);
  48. time_t mrg_metric_get_first_time_s(MRG *mrg, METRIC *metric);
  49. bool mrg_metric_set_clean_latest_time_s(MRG *mrg, METRIC *metric, time_t latest_time_s);
  50. bool mrg_metric_set_hot_latest_time_s(MRG *mrg, METRIC *metric, time_t latest_time_s);
  51. time_t mrg_metric_get_latest_time_s(MRG *mrg, METRIC *metric);
  52. bool mrg_metric_set_update_every(MRG *mrg, METRIC *metric, uint32_t update_every_s);
  53. bool mrg_metric_set_update_every_s_if_zero(MRG *mrg, METRIC *metric, uint32_t update_every_s);
  54. uint32_t mrg_metric_get_update_every_s(MRG *mrg, METRIC *metric);
  55. void mrg_metric_expand_retention(MRG *mrg, METRIC *metric, time_t first_time_s, time_t last_time_s, uint32_t update_every_s);
  56. void mrg_metric_get_retention(MRG *mrg, METRIC *metric, time_t *first_time_s, time_t *last_time_s, uint32_t *update_every_s);
  57. bool mrg_metric_zero_disk_retention(MRG *mrg __maybe_unused, METRIC *metric);
  58. bool mrg_metric_set_writer(MRG *mrg, METRIC *metric);
  59. bool mrg_metric_clear_writer(MRG *mrg, METRIC *metric);
  60. void mrg_get_statistics(MRG *mrg, struct mrg_statistics *s);
  61. size_t mrg_aral_structures(void);
  62. size_t mrg_aral_overhead(void);
  63. void mrg_update_metric_retention_and_granularity_by_uuid(
  64. MRG *mrg, Word_t section, uuid_t *uuid,
  65. time_t first_time_s, time_t last_time_s,
  66. uint32_t update_every_s, time_t now_s);
  67. #endif // DBENGINE_METRIC_H