8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 01:23:03 +01:00
firebird-mirror/doc/README.garbage_collector

39 lines
2.2 KiB
Plaintext
Raw Normal View History

2006-03-26 22:51:24 +02:00
-----------------------------------------------------------
Firebird 2.0 garbage collector
-----------------------------------------------------------
Engine knows about each record versions produced by update\delete statement
2006-03-28 06:04:23 +02:00
and can remove them as soon as oldest snapshot transaction (OST) allowed this.
This eliminates the need to read pages with these versions again by user request
(i.e. SELECT COUNT(*) FROM table) and avoids situation when these versions are
never read (of course sweep always removed all unused record versions). Also
there is high probability that needed pages still reside in the buffer cache
2006-03-26 22:51:24 +02:00
thus there are less additional disk IO needed.
Between notifying garbage collector about page with unused versions and time
when garbage collector will read this page new transaction can update record
and garbage collector can't cleanup this record if this new transaction number
2006-03-28 06:04:23 +02:00
is above OST or still active. In this case engine again notifies garbage collector
2006-03-26 22:51:24 +02:00
with this page number and it will clean up garbage at some time later (old garbage
collector will "forget" about this page until user reads it again)
2006-03-28 06:04:23 +02:00
Both cooperative and background garbage collection are now possible. To manage it
new configuration parameter "GCPolicy" was introduced. It can be set to:
2006-03-26 22:51:24 +02:00
a) cooperative - garbage collection performed only in cooperative mode, such
as before IB6. Each user request is responsible for removing unused record
versions. This is how engine works before IB6. This is only option for
2006-03-28 06:04:23 +02:00
Classic Server mode. Engine doesn't track versions produced as result of
2006-03-26 22:51:24 +02:00
update and delete statements
b) background - garbage collection performed only by background thread, such
2006-03-28 06:04:23 +02:00
as in IB6 and later. No user requests remove unused record versions.
Instead user request notifies dedicated garbage collector thread with page
number where unused record version is detected. Also engine remembers page numbers
2006-03-26 22:51:24 +02:00
where update\delete statement created backversions.
2006-03-28 06:04:23 +02:00
c) combined - both background and cooperative garbage collection are performed.
2006-03-26 22:51:24 +02:00
2006-03-28 06:04:23 +02:00
Default is "combined" for SuperServer. ClassicServer ignores this parameter and
always works in "cooperative" mode