Comments (1)
I see mdbx targets more than POSIX platforms (not reflected the README?), so it's not going to be limited to/optimized for a specific kernel's memory management style?
- Support for other OS could be added, but I don't have infrastructure and enough time to do this. For instance public and free CI-services are available for Linux and Windows, but not for FreeBSD, AIX, Solaris, QNX and so on. +ae708aa
- One of an important point of MDBX/LMDB design is to avoid any internal memory management, including optimization/cheats for specific OS.
If I just want a sparse/hash set, does that affect some limit on the number of keys in the database?
As noted in the readme MDBX provides only order maps, which implemented over B+tree of pages, that mapped from DB-file into RAM. Therefore:
- 'sparse set' is not possible.
- number of keys limited by DB size and the summary size of each record.
Actually maximal DB size on 64-bit platforms limited by RAM and/or disk space.
On 32-bit platform actually limit is near to half of 32-bit address space, but only 0x38000000 for Windows
See https://github.com/leo-yuriev/libmdbx/blob/master/src/bits.h#L390-L398
What is it not designed/good for? Highly parallel writes? Larger-than-RAM random-access reads?
All the necessary information is already in README, but its understanding requires some background and knowledge of terminology (e.g. RAF and WAF and so on).
As noted in the readme:
- MDBX allows only a single writer at any moment, no more. In other words writes are strongly serialized, i.e. parallel writes are not possible.
- all data just mapped into RAM, therefore Larger-than-RAM cases will give a RAF-corresponding swapping via OS's virtual memory mechanism.
Please read https://github.com/leo-yuriev/libmdbx#comparison-with-other-dbs an follow the link.
from libmdbx.
Related Issues (20)
- Assertion `head_txnid != head_txnid' failed when using MDBX_SAFE_NOSYNC HOT 1
- fails to compile under termux (android) (v0.11.3) HOT 1
- Inserting much data in 1 tx causing OOM Killer HOT 3
- 4Tb assert HOT 49
- mdbx_env_open returns error 22 (Invalid argument) on 32-bit Android devices HOT 10
- [mdbx::byte] better forgo char8_t and always use unsigned char HOT 1
- "make dist" error on Mac HOT 1
- Windows MSVC 16.11.9 compile error HOT 10
- MDBX_SAFE_NOSYNC clarification HOT 5
- EXC_BAD_ACCESS on older iOS devices for first launch HOT 9
- is it possible to compile libmdbx for visual studio 2008 HOT 5
- Incoherent flaw of Linux' unified page/buffer cache HOT 7
- Enable overlapping RW+RO transactions HOT 3
- Unexpected 'MDBX_PROBLEM' error when reusing cursors from read-only transactions HOT 7
- mdbx_meta_head is not defined HOT 3
- Reference mdbx4s in the bindings table HOT 2
- Documentation about shared library build only HOT 2
- Intermittent MDBX_BAD_DBI error HOT 13
- Tracking DB size increase HOT 4
- Apple's Clang 12+ and deprecation treated as error HOT 12
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from libmdbx.