-
Notifications
You must be signed in to change notification settings - Fork 259
Concurrency and networking
Similar to some other popular NoSQL solutions, tiedot does not provide ACID transactions. However, atomic operations are possible within the scope of a single document.
Before Beta release, buffer management was entirely automated and manual "commit" (flush all buffers) was not available.
Since Beta release, buffer management is still automated, but manual "commit" APIs are also supported - check out in col.go
durableInsert
, durableUpdate
durableDelete
and Flush
- these operations commit all buffers immediately without waiting for periodic buffer synchronization.
For maximum performance and scalability, tiedot only synchronizes IO operations at very low level - each data file (documents or index) has a RWMutex
(read-write lock).
There are only 4 operations which incur read lock:
- Read document ( without JSON parsing)
- Scan collection ( without JSON parsing)
- Scan hash table (all entries)
- Scan hash table (by hash key)
And only 5 operations incur write lock:
- Insert/update/delete document ( without JSON parsing)
- Put/remove hash entry
Nothing else locks!
Most of HTTP endpoints never lock, however there is a small number of operations which must "stop the world" to ensure safe operation - these operations block all other HTTP endpoints until completed:
- Create/rename/drop/scrub collection
- Create/remove index
The synchronization behaviour is controlled by a RWMutex
- "stop the world" operations put write lock on it, all other operations put read lock on it.
tiedot HTTP service is powered by HTTP server in standard Golang library net/http
.
The HTTP service:
- Serves only one database instance
- Listens on all network interfaces
- Listens on the port specified by user via CLI parameter
- Unconditionally processes all incoming requests
- Scalability is affected by
GOMAXPROCS
See "HTTP API Reference" for documentation HTTP service usage.
Once tiedot enters HTTP service mode, it keeps running in foreground until:
-
/shutdown
endpoint is called (gracefully shutdown) - Process is stopped/interrupted/killed (not good!)