mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:14:12 +08:00
mdbx: auto-coalesce of GC's records with less overhead.
This commit is contained in:
parent
47d5fa7fd4
commit
dc39ecfb9f
18
src/core.c
18
src/core.c
@ -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");
|
||||||
|
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user