diff options
author | Costa Tsaousis <costa@netdata.cloud> | 2022-11-22 02:08:51 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-11-22 02:08:51 +0200 |
commit | 4a7048fc1ffc5d5d9a1160debbfb191a4aee99b2 (patch) | |
tree | fb37d14154b71a09fce2b371b199caa6389bf48e /libnetdata | |
parent | b8d50ecc953f7962587aaae1a793827faf4ce992 (diff) |
use 2 levels of judy arrays to speed up replication on very busy parents (#14031)
* use 2 levels of judy arrays to speed up replication on very busy parents
* delete requests from judy when executed
* do not process requests when the sender is not connected; not all requests removed are executed, so count the executed accurately
* flush replication data on sender disconnect
* cache used buffer ratio in sender structure
* cleanup replication requests when they are not valid any more
* properly update inner and outer judy arrays on deletions
* detailed replication stats
* fix bug in dictionary where deletion and flushes lead to crashes
* replication should only report retention of tier 0
* replication now has 2 buffer limits 10 -> 30 %
* detailed statistics about resets and skipped requests
* register worker metrics
* added counter for waits
* make new requests discoverable
* make it continue on iterations properly
Diffstat (limited to 'libnetdata')
-rw-r--r-- | libnetdata/dictionary/dictionary.c | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/libnetdata/dictionary/dictionary.c b/libnetdata/dictionary/dictionary.c index 29456200a9..5102323b32 100644 --- a/libnetdata/dictionary/dictionary.c +++ b/libnetdata/dictionary/dictionary.c @@ -1075,6 +1075,13 @@ static inline const char *item_get_name(const DICTIONARY_ITEM *item) { return item->caller_name; } +static inline size_t item_get_name_len(const DICTIONARY_ITEM *item) { + if(item->options & ITEM_OPTION_ALLOCATED_NAME) + return string_strlen(item->string_name); + else + return strlen(item->caller_name); +} + static DICTIONARY_ITEM *dict_item_create(DICTIONARY *dict __maybe_unused, size_t *allocated_bytes, DICTIONARY_ITEM *master_item) { DICTIONARY_ITEM *item; @@ -1794,10 +1801,10 @@ void dictionary_flush(DICTIONARY *dict) { if(unlikely(!dict)) return; - // delete the index - dictionary_index_lock_wrlock(dict); - hashtable_destroy_unsafe(dict); - dictionary_index_lock_unlock(dict); +// // delete the index +// dictionary_index_lock_wrlock(dict); +// hashtable_destroy_unsafe(dict); +// dictionary_index_lock_unlock(dict); // delete all items ll_recursive_lock(dict, DICTIONARY_LOCK_WRITE); // get write lock here, to speed it up (it is recursive) @@ -1805,8 +1812,9 @@ void dictionary_flush(DICTIONARY *dict) { for (item = dict->items.list; item; item = item_next) { item_next = item->next; - if(!item_flag_check(item, ITEM_FLAG_DELETED)) - dict_item_free_or_mark_deleted(dict, item); +// if(!item_flag_check(item, ITEM_FLAG_DELETED)) +// dict_item_free_or_mark_deleted(dict, item); + dict_item_del(dict, item_get_name(item), (ssize_t)item_get_name_len(item)); } ll_recursive_unlock(dict, DICTIONARY_LOCK_WRITE); |