sqlite_aclk.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. #ifndef NETDATA_SQLITE_ACLK_H
  3. #define NETDATA_SQLITE_ACLK_H
  4. #include "sqlite3.h"
  5. #ifndef ACLK_MAX_CHART_BATCH
  6. #define ACLK_MAX_CHART_BATCH (200)
  7. #endif
  8. #ifndef ACLK_MAX_CHART_BATCH_COUNT
  9. #define ACLK_MAX_CHART_BATCH_COUNT (10)
  10. #endif
  11. #define ACLK_MAX_ALERT_UPDATES "5"
  12. #define ACLK_DATABASE_CLEANUP_FIRST (1200)
  13. #define ACLK_DATABASE_CLEANUP_INTERVAL (3600)
  14. #define ACLK_DELETE_ACK_ALERTS_INTERNAL (86400)
  15. #define ACLK_SYNC_QUERY_SIZE 512
  16. static inline void uuid_unparse_lower_fix(uuid_t *uuid, char *out)
  17. {
  18. uuid_unparse_lower(*uuid, out);
  19. out[8] = '_';
  20. out[13] = '_';
  21. out[18] = '_';
  22. out[23] = '_';
  23. }
  24. static inline int uuid_parse_fix(char *in, uuid_t uuid)
  25. {
  26. in[8] = '-';
  27. in[13] = '-';
  28. in[18] = '-';
  29. in[23] = '-';
  30. return uuid_parse(in, uuid);
  31. }
  32. static inline int claimed()
  33. {
  34. return localhost->aclk_state.claimed_id != NULL;
  35. }
  36. #define TABLE_ACLK_ALERT \
  37. "CREATE TABLE IF NOT EXISTS aclk_alert_%s (sequence_id INTEGER PRIMARY KEY, " \
  38. "alert_unique_id, date_created, date_submitted, date_cloud_ack, filtered_alert_unique_id NOT NULL, " \
  39. "UNIQUE(alert_unique_id))"
  40. #define INDEX_ACLK_ALERT1 "CREATE INDEX IF NOT EXISTS aclk_alert_index1_%s ON aclk_alert_%s (filtered_alert_unique_id)"
  41. #define INDEX_ACLK_ALERT2 "CREATE INDEX IF NOT EXISTS aclk_alert_index2_%s ON aclk_alert_%s (date_submitted)"
  42. enum aclk_database_opcode {
  43. ACLK_DATABASE_NOOP = 0,
  44. ACLK_DATABASE_CLEANUP,
  45. ACLK_DATABASE_DELETE_HOST,
  46. ACLK_DATABASE_NODE_STATE,
  47. ACLK_DATABASE_PUSH_ALERT,
  48. ACLK_DATABASE_PUSH_ALERT_CONFIG,
  49. ACLK_DATABASE_PUSH_ALERT_SNAPSHOT,
  50. ACLK_DATABASE_PUSH_ALERT_CHECKPOINT,
  51. ACLK_DATABASE_QUEUE_REMOVED_ALERTS,
  52. ACLK_DATABASE_NODE_UNREGISTER,
  53. ACLK_DATABASE_TIMER,
  54. // leave this last
  55. // we need it to check for worker utilization
  56. ACLK_MAX_ENUMERATIONS_DEFINED
  57. };
  58. struct aclk_database_cmd {
  59. enum aclk_database_opcode opcode;
  60. void *param[2];
  61. struct completion *completion;
  62. struct aclk_database_cmd *prev, *next;
  63. };
  64. typedef struct aclk_sync_cfg_t {
  65. RRDHOST *host;
  66. int alert_updates;
  67. int alert_checkpoint_req;
  68. int alert_queue_removed;
  69. time_t node_info_send_time;
  70. time_t node_collectors_send;
  71. char uuid_str[UUID_STR_LEN];
  72. char node_id[UUID_STR_LEN];
  73. char *alerts_snapshot_uuid; // will contain the snapshot_uuid value if snapshot was requested
  74. uint64_t alerts_log_first_sequence_id;
  75. uint64_t alerts_log_last_sequence_id;
  76. } aclk_sync_cfg_t;
  77. void sql_create_aclk_table(RRDHOST *host, uuid_t *host_uuid, uuid_t *node_id);
  78. void sql_aclk_sync_init(void);
  79. void aclk_push_alert_config(const char *node_id, const char *config_hash);
  80. void aclk_push_node_alert_snapshot(const char *node_id);
  81. void aclk_push_node_removed_alerts(const char *node_id);
  82. void schedule_node_info_update(RRDHOST *host);
  83. #ifdef ENABLE_ACLK
  84. void unregister_node(const char *machine_guid);
  85. #endif
  86. #endif //NETDATA_SQLITE_ACLK_H