By default, tiedot does not compile on 32-bit systems due to:
- Hash-table key-smear algorithm overflows 32-bit integer and prevents compilation.
- Data files are not split into 2GB chunks.
- Document ID generator involves using a random number source which produces platform integer (32 or 64 bits).
However, you may safely use tiedot on 32-bit systems ONLY IF there is a very small amount of data to be managed - several thousand of documents per collection (at maximum); to do so, please follow the instructions in buildconstraint.go
.
tiedot relies on memory mapped files for almost everything - just like many other NoSQL solutions.
For best performance, it is recommended (but not required) to have enough system memory to accommodate the entire data set.
Your operating system may have additional limit on the maximum size of a single memory mapped file.
A document may not exceed 2MBytes, which means:
- When inserting a new document, its size may not exceed 1MBytes.
- When updating a document, the updated version may not exceed 2MBytes.
This limit is a compile time constant, it can be easily modified in data/collection.go
(const DOC_MAX_ROOM
).
Upon creating a new database, all collections and indexes are partitioned into runtime.NumCPU()
(number of system CPUs) partitions, allowing concurrent document operations to be carried out on independent partitions. See [Concurrency and networking] for more details.
Go runtime uses GOMAXPROCS
to limit number of OS threads available to a Go program, thus it will affect the scalability of tiedot. For best performance, GOMAXPROCS
should be set to the number of system CPUs. This can be set via tiedot CLI parameter or environment variable GOMAXPROCS
.