mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 19:38:20 +08:00
mdbx: fix/setup zero mod_txnid
during copy-with-compactification.
This commit is contained in:
parent
c95143f41b
commit
f16bee8fa1
14
src/core.c
14
src/core.c
@ -19570,6 +19570,8 @@ static int compacting_put_bytes(mdbx_compacting_ctx *ctx, const void *src,
|
|||||||
assert(chunk > PAGEHDRSZ);
|
assert(chunk > PAGEHDRSZ);
|
||||||
MDBX_page *mp = dst;
|
MDBX_page *mp = dst;
|
||||||
mp->mp_pgno = pgno;
|
mp->mp_pgno = pgno;
|
||||||
|
if (mp->mp_txnid == 0)
|
||||||
|
mp->mp_txnid = ctx->mc_txn->mt_txnid;
|
||||||
if (mp->mp_flags == P_OVERFLOW) {
|
if (mp->mp_flags == P_OVERFLOW) {
|
||||||
assert(bytes <= pgno2bytes(ctx->mc_env, npages));
|
assert(bytes <= pgno2bytes(ctx->mc_env, npages));
|
||||||
mp->mp_pages = npages;
|
mp->mp_pages = npages;
|
||||||
@ -19769,12 +19771,18 @@ __cold static int compacting_walk_sdb(mdbx_compacting_ctx *ctx, MDBX_db *sdb) {
|
|||||||
|
|
||||||
couple.outer.mc_checking |= CC_SKIPORD | CC_PAGECHECK;
|
couple.outer.mc_checking |= CC_SKIPORD | CC_PAGECHECK;
|
||||||
couple.inner.mx_cursor.mc_checking |= CC_SKIPORD | CC_PAGECHECK;
|
couple.inner.mx_cursor.mc_checking |= CC_SKIPORD | CC_PAGECHECK;
|
||||||
|
if (!sdb->md_mod_txnid)
|
||||||
|
sdb->md_mod_txnid = ctx->mc_txn->mt_txnid;
|
||||||
return compacting_walk_tree(ctx, &couple.outer, &sdb->md_root,
|
return compacting_walk_tree(ctx, &couple.outer, &sdb->md_root,
|
||||||
sdb->md_mod_txnid ? sdb->md_mod_txnid
|
sdb->md_mod_txnid);
|
||||||
: ctx->mc_txn->mt_txnid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
__cold static void compacting_fixup_meta(MDBX_env *env, MDBX_meta *meta) {
|
__cold static void compacting_fixup_meta(MDBX_env *env, MDBX_meta *meta) {
|
||||||
|
mdbx_assert(env, meta->mm_dbs[FREE_DBI].md_mod_txnid ||
|
||||||
|
meta->mm_dbs[FREE_DBI].md_root == P_INVALID);
|
||||||
|
mdbx_assert(env, meta->mm_dbs[MAIN_DBI].md_mod_txnid ||
|
||||||
|
meta->mm_dbs[MAIN_DBI].md_root == P_INVALID);
|
||||||
|
|
||||||
/* Calculate filesize taking in account shrink/growing thresholds */
|
/* Calculate filesize taking in account shrink/growing thresholds */
|
||||||
if (meta->mm_geo.next != meta->mm_geo.now) {
|
if (meta->mm_geo.next != meta->mm_geo.now) {
|
||||||
meta->mm_geo.now = meta->mm_geo.next;
|
meta->mm_geo.now = meta->mm_geo.next;
|
||||||
@ -19884,6 +19892,8 @@ __cold static int mdbx_env_compact(MDBX_env *env, MDBX_txn *read_txn,
|
|||||||
int thread_err = mdbx_thread_create(&thread, compacting_write_thread, &ctx);
|
int thread_err = mdbx_thread_create(&thread, compacting_write_thread, &ctx);
|
||||||
if (likely(thread_err == MDBX_SUCCESS)) {
|
if (likely(thread_err == MDBX_SUCCESS)) {
|
||||||
if (dest_is_pipe) {
|
if (dest_is_pipe) {
|
||||||
|
if (!meta->mm_dbs[MAIN_DBI].md_mod_txnid)
|
||||||
|
meta->mm_dbs[MAIN_DBI].md_mod_txnid = read_txn->mt_txnid;
|
||||||
compacting_fixup_meta(env, meta);
|
compacting_fixup_meta(env, meta);
|
||||||
rc = mdbx_write(fd, buffer, meta_bytes);
|
rc = mdbx_write(fd, buffer, meta_bytes);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user