mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-04 17:04:13 +08:00
mdbx: rework MDBX_DBG_DUMP to avoid performance degradation.
Change-Id: I556ae61e03fdf7d6798072bbc2583ae5d01cbf9f
This commit is contained in:
parent
4eccf901ea
commit
66ca7a519e
4
mdbx.h
4
mdbx.h
@ -821,7 +821,9 @@ typedef struct iovec MDBX_val;
|
|||||||
#define MDBX_DBG_ASSERT 1 /* Enable assertion checks */
|
#define MDBX_DBG_ASSERT 1 /* Enable assertion checks */
|
||||||
#define MDBX_DBG_AUDIT 2 /* Enable pages usage audit at commit transactions */
|
#define MDBX_DBG_AUDIT 2 /* Enable pages usage audit at commit transactions */
|
||||||
#define MDBX_DBG_JITTER 4 /* Enable small random delays in critical points */
|
#define MDBX_DBG_JITTER 4 /* Enable small random delays in critical points */
|
||||||
#define MDBX_DBG_DUMP 8 /* Include or not database(s) in coredump files */
|
#define MDBX_DBG_DUMP /* Include or not meta-pages in coredump files, MAY \
|
||||||
|
affect performance in MDBX_WRITEMAP mode */ \
|
||||||
|
8
|
||||||
#define MDBX_DBG_LEGACY_MULTIOPEN 16 /* Enable multi-opening environment(s) */
|
#define MDBX_DBG_LEGACY_MULTIOPEN 16 /* Enable multi-opening environment(s) */
|
||||||
|
|
||||||
/* A debug-logger callback function,
|
/* A debug-logger callback function,
|
||||||
|
@ -8321,27 +8321,28 @@ static int __cold mdbx_setup_dxb(MDBX_env *env, const int lck_rc) {
|
|||||||
if (unlikely(err != MDBX_SUCCESS))
|
if (unlikely(err != MDBX_SUCCESS))
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
#if defined(MADV_DODUMP) && defined(MADV_DONTDUMP)
|
#if defined(MADV_DONTDUMP)
|
||||||
const size_t meta_length_aligned2os = pgno_align2os_bytes(env, NUM_METAS);
|
err = madvise(env->me_map, env->me_dxb_mmap.limit, MADV_DONTDUMP)
|
||||||
err = madvise(env->me_map, meta_length_aligned2os, MADV_DODUMP)
|
|
||||||
? ignore_enosys(errno)
|
? ignore_enosys(errno)
|
||||||
: MDBX_SUCCESS;
|
: MDBX_SUCCESS;
|
||||||
if (unlikely(MDBX_IS_ERROR(err)))
|
if (unlikely(MDBX_IS_ERROR(err)))
|
||||||
return err;
|
return err;
|
||||||
err = madvise(env->me_map + meta_length_aligned2os,
|
#endif /* MADV_DONTDUMP */
|
||||||
env->me_dxb_mmap.current - meta_length_aligned2os,
|
#if defined(MADV_DODUMP)
|
||||||
(mdbx_runtime_flags & MDBX_DBG_DUMP) ? MADV_DODUMP
|
if (mdbx_runtime_flags & MDBX_DBG_DUMP) {
|
||||||
: MADV_DONTDUMP)
|
const size_t meta_length_aligned2os = pgno_align2os_bytes(env, NUM_METAS);
|
||||||
? ignore_enosys(errno)
|
err = madvise(env->me_map, meta_length_aligned2os, MADV_DODUMP)
|
||||||
: MDBX_SUCCESS;
|
? ignore_enosys(errno)
|
||||||
if (unlikely(MDBX_IS_ERROR(err)))
|
: MDBX_SUCCESS;
|
||||||
return err;
|
if (unlikely(MDBX_IS_ERROR(err)))
|
||||||
#endif
|
return err;
|
||||||
|
}
|
||||||
|
#endif /* MADV_DODUMP */
|
||||||
|
|
||||||
#ifdef MDBX_USE_VALGRIND
|
#ifdef MDBX_USE_VALGRIND
|
||||||
env->me_valgrind_handle =
|
env->me_valgrind_handle =
|
||||||
VALGRIND_CREATE_BLOCK(env->me_map, env->me_dxb_mmap.limit, "mdbx");
|
VALGRIND_CREATE_BLOCK(env->me_map, env->me_dxb_mmap.limit, "mdbx");
|
||||||
#endif
|
#endif /* MDBX_USE_VALGRIND */
|
||||||
|
|
||||||
mdbx_assert(env, used_bytes >= pgno2bytes(env, NUM_METAS) &&
|
mdbx_assert(env, used_bytes >= pgno2bytes(env, NUM_METAS) &&
|
||||||
used_bytes <= env->me_dxb_mmap.limit);
|
used_bytes <= env->me_dxb_mmap.limit);
|
||||||
@ -15497,36 +15498,6 @@ int __cold mdbx_setup_debug(int loglevel, int flags, MDBX_debug_func *logger) {
|
|||||||
flags &= MDBX_DBG_ASSERT | MDBX_DBG_AUDIT | MDBX_DBG_JITTER |
|
flags &= MDBX_DBG_ASSERT | MDBX_DBG_AUDIT | MDBX_DBG_JITTER |
|
||||||
MDBX_DBG_DUMP | MDBX_DBG_LEGACY_MULTIOPEN;
|
MDBX_DBG_DUMP | MDBX_DBG_LEGACY_MULTIOPEN;
|
||||||
#endif
|
#endif
|
||||||
#if defined(__linux__) || defined(__gnu_linux__)
|
|
||||||
if ((mdbx_runtime_flags ^ flags) & MDBX_DBG_DUMP) {
|
|
||||||
/* http://man7.org/linux/man-pages/man5/core.5.html */
|
|
||||||
const unsigned long dump_bits =
|
|
||||||
1 << 3 /* Dump file-backed shared mappings */
|
|
||||||
| 1 << 6 /* Dump shared huge pages */
|
|
||||||
| 1 << 8 /* Dump shared DAX pages */;
|
|
||||||
const int core_filter_fd =
|
|
||||||
open("/proc/self/coredump_filter", O_TRUNC | O_RDWR);
|
|
||||||
if (core_filter_fd != -1) {
|
|
||||||
char buf[32];
|
|
||||||
intptr_t bytes = pread(core_filter_fd, buf, sizeof(buf), 0);
|
|
||||||
if (bytes > 0 && (size_t)bytes < sizeof(buf)) {
|
|
||||||
buf[bytes] = 0;
|
|
||||||
const unsigned long present_mask = strtoul(buf, NULL, 16);
|
|
||||||
const unsigned long wanna_mask = (flags & MDBX_DBG_DUMP)
|
|
||||||
? present_mask | dump_bits
|
|
||||||
: present_mask & ~dump_bits;
|
|
||||||
if (wanna_mask != present_mask) {
|
|
||||||
bytes = snprintf(buf, sizeof(buf), "0x%lx\n", wanna_mask);
|
|
||||||
if (bytes > 0 && (size_t)bytes < sizeof(buf)) {
|
|
||||||
bytes = pwrite(core_filter_fd, buf, bytes, 0);
|
|
||||||
(void)bytes;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
close(core_filter_fd);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif /* Linux */
|
|
||||||
mdbx_runtime_flags = (uint8_t)flags;
|
mdbx_runtime_flags = (uint8_t)flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1532,7 +1532,13 @@ retry_mapview:;
|
|||||||
void *ptr = mremap(map->address, map->limit, limit, 0);
|
void *ptr = mremap(map->address, map->limit, limit, 0);
|
||||||
if (ptr == MAP_FAILED) {
|
if (ptr == MAP_FAILED) {
|
||||||
rc = errno;
|
rc = errno;
|
||||||
return (rc == EAGAIN || rc == ENOMEM) ? MDBX_RESULT_TRUE : rc;
|
switch (rc) {
|
||||||
|
case EAGAIN:
|
||||||
|
case ENOMEM:
|
||||||
|
case EFAULT /* MADV_DODUMP / MADV_DONTDUMP are mixed for mmap-mange */:
|
||||||
|
rc = MDBX_RESULT_TRUE;
|
||||||
|
}
|
||||||
|
return rc;
|
||||||
}
|
}
|
||||||
map->address = ptr;
|
map->address = ptr;
|
||||||
map->limit = limit;
|
map->limit = limit;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user