8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 17:23:03 +01:00

Added TODO for Firebird 2

This commit is contained in:
skidder 2003-04-20 16:26:26 +00:00
parent 11a6724518
commit b034d016cf

85
doc/fb2-todo.txt Normal file
View File

@ -0,0 +1,85 @@
Firebird 2 architecture
Engine uses following objects in memory that are a subject
to threading contention.
1. Buffer cache
Protection: single mutex on buffer cache object.
All modification to buffers should be performed in this module only
and under mutex. Only costant pointers should be given out
(it should be working this way now - make interface declaration appropriate)
2. Metadata cache. Compiled requests + request cache
Idea of implementation: only constant objects should be stored in cache.
Use single cache-level mutex to protect addition to cache and removal from
cache. Modify objects only when they are outside of cache. Derive all cached
objects (including requests and relations) from unified cacheable object
which will allow to track object usage.
3. Lock manager data
single subsystem mutex. works well now.
4. Cached database header data (DBB) and other cached pieces of data.
Protect it with a single dbb-level mutex to avoid deadlocks.
Use temporary structures when needed to cache snapshots of this data.
Targets we are going to support under Firebird 2 architecture
1. Multi-threaded engine. Just like SuperServer, but SMP-friendly.
2. Embeeded server. The same as multi-threaded but is packaged in a single
.dll/.so module. Other differences:
- no security
- no configuration file (set params via special API call)
- built-in INTL
- internal UDF handler
3. Clustered server
Run multi-threaded engine on each cluster node. Direct page latches and
other locks to a distributed lock manager. This target should be kept in mind,
but may not be finalized in 2.0 release.
Another important thing. Engine AS IS already _is_ already suited for parallel
operation by initial design. Versioning is a great thing !
We NEED:
- just a few simple Java-like object-level mutexes
- make it run just like CS, but using several shared subsystems
We do NOT NEED:
- big amount of mutexes and mutex arrays
- relation-level mutexes and other shit like this
- multi-state mutexes as they are inherently deadlock-prone.
we should use constant objects with usage tracking or ordinary
lock manager instead
Mutexes should be aquired only for a very short periods of time.
Linked lists usage should be discouraged. All classes touched
by thread-safety cleanup (bdb, att, dbb) should be fixed to avoid
LLS usage as it is usually thread-unsafe.
TODO:
1. Implement locking objects.
2. Implement thread-safe, SMP-friendly memory manager.
3. Review every source module inside the engine regarding its MT-safety.
TODO-list might extend after this point, but not too much because we
already have SMP-friendly CS builds.
4. Fix up buffer cache to make it thread-safe,
and solve its performance problems.
5. Re-write metadata cache
6. Make JRD requests use new metadata cache
7. Make DSQL compilation thread-safe (via porting it to BISON correctly)
8. Make DSQL requests use new metadata cache
9. Implement cache of compiled requests (should be easy at this point)
10. Review all tdbb/dbb usage in TLS. In general, all functions should derive
its context only from its parameters. TLS usage should be eliminated
or at least minimized
11. Warp dbb/att access with thread-safe accessor methods using dbb-level mutex.
Review all places where it is used.
12. Kill manual thread shcheduling (sch.cpp, THREAD_ENTER/THREAD_EXIT
and company)
13. Engine should be thread-safe at this point. TEST IT !
Perform stress testing and add needed logging where required.
We need to unify debug logging across the engine.
Assignments
Nickolay Samofatov:
Points 1 and 2 are almost finished in my tree. Locking objects need some more
comparative testing. Hardware memory pages manager (1.5 uses malloc for this
purpose) is neary finished and needs testing.