mdbx: auto-coalesce of GC's records with less overhead.

This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2022-07-24 21:20:22 +03:00
parent 47d5fa7fd4
commit dc39ecfb9f
2 changed files with 8 additions and 14 deletions

View File

@ -6645,19 +6645,18 @@ __hot static pgno_t *scan4range(const MDBX_PNL pnl, const unsigned len,
#define MDBX_ALLOC_NOLOG 32 #define MDBX_ALLOC_NOLOG 32
#define MDBX_ALLOC_ALL (MDBX_ALLOC_GC | MDBX_ALLOC_NEW) #define MDBX_ALLOC_ALL (MDBX_ALLOC_GC | MDBX_ALLOC_NEW)
__cold static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, int flags) {
int flags) {
pgr_t ret; pgr_t ret;
MDBX_txn *const txn = mc->mc_txn; MDBX_txn *const txn = mc->mc_txn;
MDBX_env *const env = txn->mt_env; MDBX_env *const env = txn->mt_env;
mdbx_assert(env, num == 0 || !(flags & MDBX_ALLOC_SLOT)); mdbx_assert(env, num == 0 || !(flags & MDBX_ALLOC_SLOT));
mdbx_assert(env, num > 0 || !(flags & MDBX_ALLOC_NEW)); mdbx_assert(env, num > 0 || !(flags & MDBX_ALLOC_NEW));
const unsigned coalesce_threshold = const unsigned coalesce_threshold = env->me_maxgc_ov1page >> 2;
env->me_maxgc_ov1page - env->me_maxgc_ov1page / 4;
if (likely(flags & MDBX_ALLOC_GC)) { if (likely(flags & MDBX_ALLOC_GC)) {
flags |= env->me_flags & MDBX_LIFORECLAIM; flags |= env->me_flags & MDBX_LIFORECLAIM;
if (MDBX_PNL_SIZE(txn->tw.reclaimed_pglist) < coalesce_threshold) if (txn->mt_dbs[FREE_DBI].md_branch_pages &&
MDBX_PNL_SIZE(txn->tw.reclaimed_pglist) < coalesce_threshold)
flags |= MDBX_ALLOC_COALESCE; flags |= MDBX_ALLOC_COALESCE;
if (unlikely( if (unlikely(
/* If mc is updating the GC, then the retired-list cannot play /* If mc is updating the GC, then the retired-list cannot play
@ -6858,7 +6857,6 @@ __cold static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num,
} }
/* Merge in descending sorted order */ /* Merge in descending sorted order */
const unsigned prev_re_len = MDBX_PNL_SIZE(re_list);
pnl_merge(re_list, gc_pnl); pnl_merge(re_list, gc_pnl);
if (mdbx_audit_enabled() && if (mdbx_audit_enabled() &&
unlikely(!mdbx_pnl_check(re_list, txn->mt_next_pgno))) { unlikely(!mdbx_pnl_check(re_list, txn->mt_next_pgno))) {
@ -6891,17 +6889,13 @@ __cold static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num,
} }
/* Don't try to coalesce too much. */ /* Don't try to coalesce too much. */
if (flags & MDBX_ALLOC_COALESCE) { if (re_len /* current size */ > coalesce_threshold) {
if (re_len /* current size */ > coalesce_threshold || if (flags & MDBX_ALLOC_COALESCE)
(re_len > prev_re_len &&
re_len - prev_re_len /* delta from prev */ >=
coalesce_threshold / 2)) {
mdbx_trace("clear %s %s", "MDBX_ALLOC_COALESCE", mdbx_trace("clear %s %s", "MDBX_ALLOC_COALESCE",
"since got threshold"); "since got threshold");
flags &= ~MDBX_ALLOC_COALESCE; flags &= ~MDBX_ALLOC_COALESCE;
} }
} }
}
if (F_ISSET(flags, MDBX_ALLOC_COALESCE | MDBX_ALLOC_GC)) { if (F_ISSET(flags, MDBX_ALLOC_COALESCE | MDBX_ALLOC_GC)) {
mdbx_debug_extra("clear %s and continue", "MDBX_ALLOC_COALESCE"); mdbx_debug_extra("clear %s and continue", "MDBX_ALLOC_COALESCE");

View File

@ -1109,7 +1109,7 @@ struct MDBX_env {
#define MDBX_ENV_TXKEY UINT32_C(0x10000000) #define MDBX_ENV_TXKEY UINT32_C(0x10000000)
/* Legacy MDBX_MAPASYNC (prior v0.9) */ /* Legacy MDBX_MAPASYNC (prior v0.9) */
#define MDBX_DEPRECATED_MAPASYNC UINT32_C(0x100000) #define MDBX_DEPRECATED_MAPASYNC UINT32_C(0x100000)
/* Legacy MDBX_MAPASYNC (prior v0.12) */ /* Legacy MDBX_COALESCE (prior v0.12) */
#define MDBX_DEPRECATED_COALESCE UINT32_C(0x2000000) #define MDBX_DEPRECATED_COALESCE UINT32_C(0x2000000)
#define ENV_INTERNAL_FLAGS (MDBX_FATAL_ERROR | MDBX_ENV_ACTIVE | MDBX_ENV_TXKEY) #define ENV_INTERNAL_FLAGS (MDBX_FATAL_ERROR | MDBX_ENV_ACTIVE | MDBX_ENV_TXKEY)
uint32_t me_flags; uint32_t me_flags;