天天看點

Aerospike partition tree的記憶體管理

as_namespaces_init:

1、uint32_t stage_capacity = as_mem_check()
     for (capacity = MAX_STAGE_CAPACITY; capacity >= MIN_STAGE_CAPACITY; capacity /= 2) {
         if (check_capacity(capacity)) {
             break;
         }
     }      

    申請的記憶體大小以16M開始,如果記憶體大小不夠用,則申請16/2M依次類推,最小大小是2M

2、as_namespaces_setup(cold_start_cmd, instance, stage_capacity);
     ->setup_namespace(g_config.namespaces[i], stage_capacity);
     ->ns->arena = (cf_arenax*)cf_malloc(cf_arenax_sizeof());
       cf_arenax_err arena_result = cf_arenax_create(ns->arena, 0, 
         as_index_size_get(ns), stage_capacity, 0, CF_ARENAX_BIGLOCK);
     ->uint64_t stage_size = (uint64_t)stage_capacity * sizeof(as_index);
       memset(this->stages, 0, sizeof(this->stages));
       uint8_t* p_stage = (uint8_t*)cf_malloc(this->stage_size);
       this->stages[this->stage_count++] = p_stage;
       memset(cf_arenax_resolve(this, 0), 0, sizeof(as_index));      

    ns->arena->stages[256]共有256個記憶體stage。

     最開始,隻申請對第一個stages申請16M*sizeof(as_index)的記憶體空間。

3、as_partition_init(ns, pid);
     ->p->vp = as_index_tree_create(&ns->tree_shared, ns->arena);
     ->tree->arena = arena;      

    對partition進行初始化,樹的記憶體都是共用一個arena,即ns->arena

while (cf_queue_pop(&g_gc_queue, &tree, CF_QUEUE_FOREVER) == CF_QUEUE_OK) {
        as_index_tree_destroy(tree);
     }      

繼續閱讀