mdbx: rework MDBX_DBG_DUMP to avoid performance degradation.

Change-Id: I556ae61e03fdf7d6798072bbc2583ae5d01cbf9f
This commit is contained in:
Leonid Yuriev 2019-12-17 02:59:13 +03:00
parent 4eccf901ea
commit 66ca7a519e
3 changed files with 24 additions and 45 deletions

4
mdbx.h
View File

@ -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,

View File

@ -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;
} }

View File

@ -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;