1 #include "registry_internals.h"
3 int registry_init(void) {
4 char filename[FILENAME_MAX + 1];
7 registry.enabled = config_get_boolean("registry", "enabled", 0);
10 snprintfz(filename, FILENAME_MAX, "%s/registry", netdata_configured_varlib_dir);
11 registry.pathname = config_get("registry", "registry db directory", filename);
12 if(mkdir(registry.pathname, 0770) == -1 && errno != EEXIST)
13 fatal("Cannot create directory '%s'.", registry.pathname);
16 snprintfz(filename, FILENAME_MAX, "%s/netdata.public.unique.id", registry.pathname);
17 registry.machine_guid_filename = config_get("registry", "netdata unique id file", filename);
18 registry_get_this_machine_guid();
20 snprintfz(filename, FILENAME_MAX, "%s/registry.db", registry.pathname);
21 registry.db_filename = config_get("registry", "registry db file", filename);
23 snprintfz(filename, FILENAME_MAX, "%s/registry-log.db", registry.pathname);
24 registry.log_filename = config_get("registry", "registry log file", filename);
26 // configuration options
27 registry.save_registry_every_entries = (unsigned long long)config_get_number("registry", "registry save db every new entries", 1000000);
28 registry.persons_expiration = config_get_number("registry", "registry expire idle persons days", 365) * 86400;
29 registry.registry_domain = config_get("registry", "registry domain", "");
30 registry.registry_to_announce = config_get("registry", "registry to announce", "https://registry.my-netdata.io");
31 registry.hostname = config_get("registry", "registry hostname", config_get("global", "hostname", localhost.hostname));
32 registry.verify_cookies_redirects = config_get_boolean("registry", "verify browser cookies support", 1);
34 setenv("NETDATA_REGISTRY_HOSTNAME", registry.hostname, 1);
35 setenv("NETDATA_REGISTRY_URL", registry.registry_to_announce, 1);
37 registry.max_url_length = (size_t)config_get_number("registry", "max URL length", 1024);
38 if(registry.max_url_length < 10) {
39 registry.max_url_length = 10;
40 config_set_number("registry", "max URL length", (long long)registry.max_url_length);
43 registry.max_name_length = (size_t)config_get_number("registry", "max URL name length", 50);
44 if(registry.max_name_length < 10) {
45 registry.max_name_length = 10;
46 config_set_number("registry", "max URL name length", (long long)registry.max_name_length);
49 // initialize entries counters
50 registry.persons_count = 0;
51 registry.machines_count = 0;
52 registry.usages_count = 0;
53 registry.urls_count = 0;
54 registry.persons_urls_count = 0;
55 registry.machines_urls_count = 0;
57 // initialize memory counters
58 registry.persons_memory = 0;
59 registry.machines_memory = 0;
60 registry.urls_memory = 0;
61 registry.persons_urls_memory = 0;
62 registry.machines_urls_memory = 0;
65 pthread_mutex_init(®istry.lock, NULL);
67 // create dictionaries
68 registry.persons = dictionary_create(DICTIONARY_FLAGS);
69 registry.machines = dictionary_create(DICTIONARY_FLAGS);
70 avl_init(®istry.registry_urls_root_index, registry_url_compare);
72 // load the registry database
73 if(registry.enabled) {
78 if(unlikely(registry_db_should_be_saved()))
85 void registry_free(void) {
86 if(!registry.enabled) return;
88 // we need to destroy the dictionaries ourselves
89 // since the dictionaries use memory we allocated
91 while(registry.persons->values_index.root) {
92 REGISTRY_PERSON *p = ((NAME_VALUE *)registry.persons->values_index.root)->value;
93 registry_person_del(p);
96 while(registry.machines->values_index.root) {
97 REGISTRY_MACHINE *m = ((NAME_VALUE *)registry.machines->values_index.root)->value;
99 // fprintf(stderr, "\nMACHINE: '%s', first: %u, last: %u, usages: %u\n", m->guid, m->first_t, m->last_t, m->usages);
101 while(m->machine_urls->values_index.root) {
102 REGISTRY_MACHINE_URL *mu = ((NAME_VALUE *)m->machine_urls->values_index.root)->value;
104 // fprintf(stderr, "\tURL: '%s', first: %u, last: %u, usages: %u, flags: 0x%02x\n", mu->url->url, mu->first_t, mu->last_t, mu->usages, mu->flags);
106 //debug(D_REGISTRY, "Registry: destroying persons dictionary from url '%s'", mu->url->url);
107 //dictionary_destroy(mu->persons);
109 debug(D_REGISTRY, "Registry: deleting url '%s' from person '%s'", mu->url->url, m->guid);
110 dictionary_del(m->machine_urls, mu->url->url);
112 debug(D_REGISTRY, "Registry: unlinking url '%s' from machine", mu->url->url);
113 registry_url_unlink(mu->url);
115 debug(D_REGISTRY, "Registry: freeing machine url");
119 debug(D_REGISTRY, "Registry: deleting machine '%s' from machines registry", m->guid);
120 dictionary_del(registry.machines, m->guid);
122 debug(D_REGISTRY, "Registry: destroying URL dictionary of machine '%s'", m->guid);
123 dictionary_destroy(m->machine_urls);
125 debug(D_REGISTRY, "Registry: freeing machine '%s'", m->guid);
129 // and free the memory of remaining dictionary structures
131 debug(D_REGISTRY, "Registry: destroying persons dictionary");
132 dictionary_destroy(registry.persons);
134 debug(D_REGISTRY, "Registry: destroying machines dictionary");
135 dictionary_destroy(registry.machines);