mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:38:20 +08:00
mdbx: исправление лишнего сброса данных на диск в режиме MDBX_SAFE_NOSYNC
при обновлении GC.
This commit is contained in:
parent
0f7e5073db
commit
92dabe1ad1
23
src/core.c
23
src/core.c
@ -6351,8 +6351,8 @@ static pgno_t *scan4seq_resolver(pgno_t *range, const size_t len,
|
|||||||
#define MDBX_ALLOC_NEW 2
|
#define MDBX_ALLOC_NEW 2
|
||||||
#define MDBX_ALLOC_COALESCE 4
|
#define MDBX_ALLOC_COALESCE 4
|
||||||
#define MDBX_ALLOC_SLOT 8
|
#define MDBX_ALLOC_SLOT 8
|
||||||
#define MDBX_ALLOC_FAKE 16
|
#define MDBX_ALLOC_RESERVE 16
|
||||||
#define MDBX_ALLOC_NOLOG 32
|
#define MDBX_ALLOC_BACKLOG 32
|
||||||
#define MDBX_ALLOC_ALL (MDBX_ALLOC_GC | MDBX_ALLOC_NEW)
|
#define MDBX_ALLOC_ALL (MDBX_ALLOC_GC | MDBX_ALLOC_NEW)
|
||||||
|
|
||||||
static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, int flags) {
|
static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, int flags) {
|
||||||
@ -6657,7 +6657,7 @@ static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, int flags) {
|
|||||||
DEBUG("gc-wipe-steady, rc %d", ret.err);
|
DEBUG("gc-wipe-steady, rc %d", ret.err);
|
||||||
eASSERT(env, prefer_steady.ptr_c !=
|
eASSERT(env, prefer_steady.ptr_c !=
|
||||||
meta_prefer_steady(env, &txn->tw.troika).ptr_c);
|
meta_prefer_steady(env, &txn->tw.troika).ptr_c);
|
||||||
} else if ((flags & MDBX_ALLOC_NEW) == 0 ||
|
} else if ((flags & (MDBX_ALLOC_BACKLOG | MDBX_ALLOC_NEW)) == 0 ||
|
||||||
(autosync_threshold &&
|
(autosync_threshold &&
|
||||||
atomic_load32(&env->me_lck->mti_unsynced_pages,
|
atomic_load32(&env->me_lck->mti_unsynced_pages,
|
||||||
mo_Relaxed) >= autosync_threshold) ||
|
mo_Relaxed) >= autosync_threshold) ||
|
||||||
@ -6736,12 +6736,12 @@ static pgr_t page_alloc_slowpath(MDBX_cursor *mc, const pgno_t num, int flags) {
|
|||||||
txn->mt_next_pgno - MDBX_ENABLE_REFUND));
|
txn->mt_next_pgno - MDBX_ENABLE_REFUND));
|
||||||
int level;
|
int level;
|
||||||
const char *what;
|
const char *what;
|
||||||
if (likely(!(flags & MDBX_ALLOC_FAKE))) {
|
if (likely(!(flags & MDBX_ALLOC_RESERVE))) {
|
||||||
txn->mt_flags |= MDBX_TXN_ERROR;
|
txn->mt_flags |= MDBX_TXN_ERROR;
|
||||||
level = MDBX_LOG_ERROR;
|
level = MDBX_LOG_ERROR;
|
||||||
what = "pages";
|
what = "pages";
|
||||||
} else {
|
} else {
|
||||||
level = (flags & MDBX_ALLOC_NOLOG) ? MDBX_LOG_DEBUG : MDBX_LOG_NOTICE;
|
level = (flags & MDBX_ALLOC_BACKLOG) ? MDBX_LOG_DEBUG : MDBX_LOG_NOTICE;
|
||||||
what = (flags & MDBX_ALLOC_SLOT) ? "gc-slot/backlog" : "backlog-pages";
|
what = (flags & MDBX_ALLOC_SLOT) ? "gc-slot/backlog" : "backlog-pages";
|
||||||
}
|
}
|
||||||
if (LOG_ENABLED(level))
|
if (LOG_ENABLED(level))
|
||||||
@ -6761,9 +6761,8 @@ done:
|
|||||||
if (likely(timestamp))
|
if (likely(timestamp))
|
||||||
env->me_lck->mti_pgop_stat.gcrtime.weak += osal_monotime() - timestamp;
|
env->me_lck->mti_pgop_stat.gcrtime.weak += osal_monotime() - timestamp;
|
||||||
#endif /* MDBX_ENABLE_PGOP_STAT */
|
#endif /* MDBX_ENABLE_PGOP_STAT */
|
||||||
if (unlikely(flags & MDBX_ALLOC_FAKE)) {
|
if (unlikely(flags & MDBX_ALLOC_RESERVE)) {
|
||||||
DEBUG("return NULL-page for %u pages %s allocation", num,
|
DEBUG("return NULL for %u pages %s reservation", num, "gc-slot/backlog");
|
||||||
"gc-slot/backlog");
|
|
||||||
ret.page = NULL;
|
ret.page = NULL;
|
||||||
ret.err = MDBX_SUCCESS;
|
ret.err = MDBX_SUCCESS;
|
||||||
return ret;
|
return ret;
|
||||||
@ -9135,7 +9134,7 @@ static int gcu_prepare_backlog(MDBX_txn *txn, gcu_context_t *ctx,
|
|||||||
if (unlikely(err != MDBX_SUCCESS))
|
if (unlikely(err != MDBX_SUCCESS))
|
||||||
return err;
|
return err;
|
||||||
err = page_alloc_slowpath(&ctx->cursor.outer, (pgno_t)pages4retiredlist,
|
err = page_alloc_slowpath(&ctx->cursor.outer, (pgno_t)pages4retiredlist,
|
||||||
MDBX_ALLOC_GC | MDBX_ALLOC_FAKE)
|
MDBX_ALLOC_GC | MDBX_ALLOC_RESERVE)
|
||||||
.err;
|
.err;
|
||||||
TRACE("== after-4linear, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
TRACE("== after-4linear, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
||||||
cASSERT(&ctx->cursor.outer,
|
cASSERT(&ctx->cursor.outer,
|
||||||
@ -9146,7 +9145,7 @@ static int gcu_prepare_backlog(MDBX_txn *txn, gcu_context_t *ctx,
|
|||||||
err == MDBX_SUCCESS)
|
err == MDBX_SUCCESS)
|
||||||
err = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
err = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
||||||
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
||||||
MDBX_ALLOC_FAKE | MDBX_ALLOC_NOLOG)
|
MDBX_ALLOC_RESERVE | MDBX_ALLOC_BACKLOG)
|
||||||
.err;
|
.err;
|
||||||
|
|
||||||
ctx->cursor.outer.mc_flags |= C_RECLAIMING;
|
ctx->cursor.outer.mc_flags |= C_RECLAIMING;
|
||||||
@ -9329,7 +9328,7 @@ retry:
|
|||||||
txn->tw.loose_count);
|
txn->tw.loose_count);
|
||||||
rc = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
rc = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
||||||
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
||||||
MDBX_ALLOC_FAKE)
|
MDBX_ALLOC_RESERVE)
|
||||||
.err;
|
.err;
|
||||||
if (rc == MDBX_SUCCESS) {
|
if (rc == MDBX_SUCCESS) {
|
||||||
TRACE("%s: retry since gc-slot for %zu loose-pages available",
|
TRACE("%s: retry since gc-slot for %zu loose-pages available",
|
||||||
@ -9554,7 +9553,7 @@ retry:
|
|||||||
snap_oldest = txn_oldest_reader(txn);
|
snap_oldest = txn_oldest_reader(txn);
|
||||||
rc = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
rc = page_alloc_slowpath(&ctx->cursor.outer, 0,
|
||||||
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
MDBX_ALLOC_GC | MDBX_ALLOC_SLOT |
|
||||||
MDBX_ALLOC_FAKE)
|
MDBX_ALLOC_RESERVE)
|
||||||
.err;
|
.err;
|
||||||
if (likely(rc == MDBX_SUCCESS)) {
|
if (likely(rc == MDBX_SUCCESS)) {
|
||||||
TRACE("%s: took @%" PRIaTXN " from GC", dbg_prefix_mode,
|
TRACE("%s: took @%" PRIaTXN " from GC", dbg_prefix_mode,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user