Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
04fb05b1
Commit
04fb05b1
authored
Sep 11, 2007
by
inaam
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branches/zip: undo changes made in r1763.
These should have gone in branches/fts Spotted by: Marko and Ken
parent
538665bc
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
14 additions
and
38 deletions
+14
-38
buf/buf0buf.c
buf/buf0buf.c
+10
-29
include/buf0buf.ic
include/buf0buf.ic
+4
-9
No files found.
buf/buf0buf.c
View file @
04fb05b1
...
...
@@ -135,35 +135,16 @@ The LRU-list contains all the blocks holding a file page
except those for which the bufferfix count is non-zero.
The pages are in the LRU list roughly in the order of the last
access to the page, so that the oldest pages are at the end of the
list. The LRU logic has two optimizations implemented in it.
Artificial aging of pages:
--------------------------
This is achieved by maintaining a pointer at 3/8 from the tail of
the LRU. All pages that are read in are inserted at this location.
The pages are moved to the front of LRU when they are *accessed*.
How this helps? A regular read request will result in immediately
accessing the page and the block will be moved to the front of the
LRU. The reads done as part of read-ahead mechanism (random read-ahead,
linear read-ahead etc.) will leave these pages in the lower 3/8 of the
LRU. If these pages are not accessed they will be eventually evicted
without polluting the whole buffer cache.
Reduced LRU manipulation:
-------------------------
In a classic LRU each access to a page should result in putting it
to the front of LRU. LRU manipulation, however, can lead to mutex
contention. To avoid this, we only make a block "young" if we see
that it has slipped past the top 1/4th of the LRU.
We implement this heuristic by maintaining a freed_page_clock at the
buffer pool level and in each block as well. By comparing these two
values, without holding any locks, we can determine how far a block is
from the front of LRU.
Both these clocks start ticking only after victim eviction has started
in earnest (i.e.: no blocks in free list). Hence we cannot determine
location of a block during the initial warm up phase and, therefore, we
disable this optimization during that period. Look at
buf_block_peek_if_too_old() in include/buf0buf.ic
list. We also keep a pointer to near the end of the LRU list,
which we can use when we want to artificially age a page in the
buf_pool. This is used if we know that some page is not needed
again for some time: we insert the block right after the pointer,
causing it to be replaced sooner than would noramlly be the case.
Currently this aging mechanism is used for read-ahead mechanism
of pages, and it can also be used when there is a scan of a full
table which cannot fit in the memory. Putting the pages near the
of the LRU list, we make sure that most of the buf_pool stays in the
main memory, undisturbed.
The chain of modified blocks contains the blocks
holding file pages that have been modified in the memory
...
...
include/buf0buf.ic
View file @
04fb05b1
...
...
@@ -38,11 +38,7 @@ buf_block_get_freed_page_clock(
/************************************************************************
Recommends a move of a block to the start of the LRU list if there is danger
of dropping from the buffer pool. NOTE: does not reserve the buffer pool
mutex.
Note that freed_page_clock for both buf_pool and block starts ticking
only after the buffer_cache has warmed up. During the initial warmup
phase these values are set to zero. We always recommend to to move the
block to the start of the LRU in this case. */
mutex. */
UNIV_INLINE
ibool
buf_page_peek_if_too_old(
...
...
@@ -51,10 +47,9 @@ buf_page_peek_if_too_old(
younger */
const buf_page_t* bpage) /* in: block to make younger */
{
return(buf_pool->freed_page_clock == 0
|| (buf_pool->freed_page_clock
return(buf_pool->freed_page_clock
>= buf_page_get_freed_page_clock(bpage)
+ 1 + (buf_pool->curr_size / 4)
));
+ 1 + (buf_pool->curr_size / 4
));
}
/*************************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment