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
69c18ca5
Commit
69c18ca5
authored
Oct 01, 2007
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
ma_recovery.c:
SCCS merged storage/maria/ma_recovery.c: SCCS merged
parents
301a31fd
e71e5893
Changes
16
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
456 additions
and
212 deletions
+456
-212
BUILD/SETUP.sh
BUILD/SETUP.sh
+1
-0
sql/opt_range.cc
sql/opt_range.cc
+0
-3
storage/maria/ma_blockrec.c
storage/maria/ma_blockrec.c
+54
-24
storage/maria/ma_loghandler.c
storage/maria/ma_loghandler.c
+167
-57
storage/maria/ma_loghandler.h
storage/maria/ma_loghandler.h
+7
-1
storage/maria/ma_open.c
storage/maria/ma_open.c
+3
-1
storage/maria/ma_pagecache.c
storage/maria/ma_pagecache.c
+80
-56
storage/maria/ma_pagecache.h
storage/maria/ma_pagecache.h
+21
-23
storage/maria/ma_recovery.c
storage/maria/ma_recovery.c
+81
-24
storage/maria/maria_chk.c
storage/maria/maria_chk.c
+2
-2
storage/maria/maria_def.h
storage/maria/maria_def.h
+3
-3
storage/maria/maria_read_log.c
storage/maria/maria_read_log.c
+33
-14
storage/maria/unittest/ma_control_file-t.c
storage/maria/unittest/ma_control_file-t.c
+1
-1
storage/maria/unittest/ma_test_loghandler-t.c
storage/maria/unittest/ma_test_loghandler-t.c
+1
-1
storage/maria/unittest/ma_test_loghandler_multigroup-t.c
storage/maria/unittest/ma_test_loghandler_multigroup-t.c
+1
-1
storage/maria/unittest/ma_test_loghandler_multithread-t.c
storage/maria/unittest/ma_test_loghandler_multithread-t.c
+1
-1
No files found.
BUILD/SETUP.sh
View file @
69c18ca5
...
@@ -145,6 +145,7 @@ base_configs="--prefix=$prefix --enable-assembler "
...
@@ -145,6 +145,7 @@ base_configs="--prefix=$prefix --enable-assembler "
base_configs
=
"
$base_configs
--with-extra-charsets=complex "
base_configs
=
"
$base_configs
--with-extra-charsets=complex "
base_configs
=
"
$base_configs
--enable-thread-safe-client "
base_configs
=
"
$base_configs
--enable-thread-safe-client "
base_configs
=
"
$base_configs
--with-big-tables"
base_configs
=
"
$base_configs
--with-big-tables"
base_configs
=
"
$base_configs
--with-plugin-maria"
if
test
-d
"
$path
/../cmd-line-utils/readline"
if
test
-d
"
$path
/../cmd-line-utils/readline"
then
then
...
...
sql/opt_range.cc
View file @
69c18ca5
...
@@ -2130,9 +2130,6 @@ int SQL_SELECT::test_quick_select(THD *thd, key_map keys_to_use,
...
@@ -2130,9 +2130,6 @@ int SQL_SELECT::test_quick_select(THD *thd, key_map keys_to_use,
quick
=
0
;
quick
=
0
;
needed_reg
.
clear_all
();
needed_reg
.
clear_all
();
quick_keys
.
clear_all
();
quick_keys
.
clear_all
();
if
((
specialflag
&
SPECIAL_SAFE_MODE
)
&&
!
force_quick_range
||
!
limit
)
DBUG_RETURN
(
0
);
/* purecov: inspected */
if
(
keys_to_use
.
is_clear_all
())
if
(
keys_to_use
.
is_clear_all
())
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
records
=
head
->
file
->
stats
.
records
;
records
=
head
->
file
->
stats
.
records
;
...
...
storage/maria/ma_blockrec.c
View file @
69c18ca5
...
@@ -4609,6 +4609,9 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4609,6 +4609,9 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
uint
block_size
=
share
->
block_size
;
uint
block_size
=
share
->
block_size
;
uint
rec_offset
;
uint
rec_offset
;
uchar
*
buff
=
info
->
keyread_buff
,
*
dir
;
uchar
*
buff
=
info
->
keyread_buff
,
*
dir
;
MARIA_PINNED_PAGE
page_link
;
enum
pagecache_page_lock
unlock_method
;
enum
pagecache_page_pin
unpin_method
;
DBUG_ENTER
(
"_ma_apply_redo_insert_row_head_or_tail"
);
DBUG_ENTER
(
"_ma_apply_redo_insert_row_head_or_tail"
);
info
->
keyread_buff_used
=
1
;
info
->
keyread_buff_used
=
1
;
...
@@ -4635,26 +4638,31 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4635,26 +4638,31 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
empty_space
=
(
block_size
-
PAGE_OVERHEAD_SIZE
);
empty_space
=
(
block_size
-
PAGE_OVERHEAD_SIZE
);
rec_offset
=
PAGE_HEADER_SIZE
;
rec_offset
=
PAGE_HEADER_SIZE
;
dir
=
buff
+
block_size
-
PAGE_SUFFIX_SIZE
-
DIR_ENTRY_SIZE
;
dir
=
buff
+
block_size
-
PAGE_SUFFIX_SIZE
-
DIR_ENTRY_SIZE
;
unlock_method
=
PAGECACHE_LOCK_LEFT_UNLOCKED
;
unpin_method
=
PAGECACHE_PIN_LEFT_UNPINNED
;
}
}
else
else
{
{
uint
max_entry
;
uint
max_entry
;
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
&
info
->
dfile
,
&
info
->
dfile
,
page
,
0
,
0
,
page
,
0
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_WRITE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
&
page_link
.
link
)))
PAGECACHE_LOCK_LEFT_UNLOCKED
,
0
)))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
if
(
lsn_korr
(
buff
)
>=
lsn
)
if
(
lsn_korr
(
buff
)
>=
lsn
)
/* Test if already applied */
{
{
/* Already applied */
pagecache_unlock_by_link
(
share
->
pagecache
,
page_link
.
link
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
LSN_IMPOSSIBLE
,
LSN_IMPOSSIBLE
);
/* Fix bitmap, just in case */
/* Fix bitmap, just in case */
empty_space
=
uint2korr
(
buff
+
EMPTY_SPACE_OFFSET
);
empty_space
=
uint2korr
(
buff
+
EMPTY_SPACE_OFFSET
);
if
(
_ma_bitmap_set
(
info
,
page
,
page_type
==
HEAD_PAGE
,
empty_space
))
if
(
_ma_bitmap_set
(
info
,
page
,
page_type
==
HEAD_PAGE
,
empty_space
))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
unlock_method
=
PAGECACHE_LOCK_WRITE_UNLOCK
;
unpin_method
=
PAGECACHE_UNPIN
;
max_entry
=
(
uint
)
((
uchar
*
)
buff
)[
DIR_COUNT_OFFSET
];
max_entry
=
(
uint
)
((
uchar
*
)
buff
)[
DIR_COUNT_OFFSET
];
if
(((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
!=
page_type
))
if
(((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
!=
page_type
))
...
@@ -4725,8 +4733,7 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4725,8 +4733,7 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
if
(
pagecache_write
(
share
->
pagecache
,
if
(
pagecache_write
(
share
->
pagecache
,
&
info
->
dfile
,
page
,
0
,
&
info
->
dfile
,
page
,
0
,
buff
,
PAGECACHE_PLAIN_PAGE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_LEFT_UNLOCKED
,
unlock_method
,
unpin_method
,
PAGECACHE_PIN_LEFT_UNPINNED
,
PAGECACHE_WRITE_DELAY
,
0
))
PAGECACHE_WRITE_DELAY
,
0
))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
...
@@ -4747,6 +4754,11 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4747,6 +4754,11 @@ uint _ma_apply_redo_insert_row_head_or_tail(MARIA_HA *info, LSN lsn,
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
err:
err:
if
(
unlock_method
==
PAGECACHE_LOCK_WRITE_UNLOCK
)
pagecache_unlock_by_link
(
share
->
pagecache
,
page_link
.
link
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
LSN_IMPOSSIBLE
,
LSN_IMPOSSIBLE
);
DBUG_RETURN
(
HA_ERR_WRONG_IN_RECORD
);
DBUG_RETURN
(
HA_ERR_WRONG_IN_RECORD
);
}
}
...
@@ -4778,6 +4790,8 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4778,6 +4790,8 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
uint
rownr
,
empty_space
;
uint
rownr
,
empty_space
;
uint
block_size
=
share
->
block_size
;
uint
block_size
=
share
->
block_size
;
uchar
*
buff
=
info
->
keyread_buff
;
uchar
*
buff
=
info
->
keyread_buff
;
int
result
;
MARIA_PINNED_PAGE
page_link
;
DBUG_ENTER
(
"_ma_apply_redo_purge_row_head_or_tail"
);
DBUG_ENTER
(
"_ma_apply_redo_purge_row_head_or_tail"
);
page
=
page_korr
(
header
);
page
=
page_korr
(
header
);
...
@@ -4788,11 +4802,10 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4788,11 +4802,10 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
info
->
keyread_buff_used
=
1
;
info
->
keyread_buff_used
=
1
;
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
&
info
->
dfile
,
&
info
->
dfile
,
page
,
0
,
0
,
page
,
0
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_WRITE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
&
page_link
.
link
)))
PAGECACHE_LOCK_LEFT_UNLOCKED
,
0
)))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
if
(
lsn_korr
(
buff
)
>=
lsn
)
if
(
lsn_korr
(
buff
)
>=
lsn
)
...
@@ -4802,6 +4815,11 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4802,6 +4815,11 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
Note that in case the page is not anymore a head or tail page
Note that in case the page is not anymore a head or tail page
a future redo will fix the bitmap.
a future redo will fix the bitmap.
*/
*/
pagecache_unlock_by_link
(
share
->
pagecache
,
page_link
.
link
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
LSN_IMPOSSIBLE
,
LSN_IMPOSSIBLE
);
if
((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
==
page_type
)
if
((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
==
page_type
)
{
{
empty_space
=
uint2korr
(
buff
+
EMPTY_SPACE_OFFSET
);
empty_space
=
uint2korr
(
buff
+
EMPTY_SPACE_OFFSET
);
...
@@ -4815,22 +4833,30 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
...
@@ -4815,22 +4833,30 @@ uint _ma_apply_redo_purge_row_head_or_tail(MARIA_HA *info, LSN lsn,
DBUG_ASSERT
((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
==
(
uchar
)
page_type
);
DBUG_ASSERT
((
buff
[
PAGE_TYPE_OFFSET
]
&
PAGE_TYPE_MASK
)
==
(
uchar
)
page_type
);
if
(
delete_dir_entry
(
buff
,
block_size
,
rownr
,
&
empty_space
)
<
0
)
if
(
delete_dir_entry
(
buff
,
block_size
,
rownr
,
&
empty_space
)
<
0
)
DBUG_RETURN
(
HA_ERR_WRONG_IN_RECORD
)
;
goto
err
;
lsn_store
(
buff
,
lsn
);
lsn_store
(
buff
,
lsn
);
result
=
0
;
if
(
pagecache_write
(
share
->
pagecache
,
if
(
pagecache_write
(
share
->
pagecache
,
&
info
->
dfile
,
page
,
0
,
&
info
->
dfile
,
page
,
0
,
buff
,
PAGECACHE_PLAIN_PAGE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_LEFT_UNLOCKED
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
PAGECACHE_PIN_LEFT_UNPINNED
,
PAGECACHE_WRITE_DELAY
,
0
))
PAGECACHE_WRITE_DELAY
,
0
))
DBUG_RETURN
(
my_errno
)
;
result
=
my_errno
;
/* This will work even if the page was marked as UNALLOCATED_PAGE */
/* This will work even if the page was marked as UNALLOCATED_PAGE */
if
(
_ma_bitmap_set
(
info
,
page
,
page_type
==
HEAD_PAGE
,
empty_space
))
if
(
_ma_bitmap_set
(
info
,
page
,
page_type
==
HEAD_PAGE
,
empty_space
))
DBUG_RETURN
(
my_errno
);
result
=
my_errno
;
DBUG_RETURN
(
result
);
err:
pagecache_unlock_by_link
(
share
->
pagecache
,
page_link
.
link
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
LSN_IMPOSSIBLE
,
LSN_IMPOSSIBLE
);
DBUG_RETURN
(
HA_ERR_WRONG_IN_RECORD
);
DBUG_RETURN
(
0
);
}
}
...
@@ -4872,16 +4898,21 @@ uint _ma_apply_redo_purge_blocks(MARIA_HA *info,
...
@@ -4872,16 +4898,21 @@ uint _ma_apply_redo_purge_blocks(MARIA_HA *info,
for
(
i
=
0
;
i
<
page_range
;
i
++
)
for
(
i
=
0
;
i
<
page_range
;
i
++
)
{
{
MARIA_PINNED_PAGE
page_link
;
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
if
(
!
(
buff
=
pagecache_read
(
share
->
pagecache
,
&
info
->
dfile
,
&
info
->
dfile
,
page
+
i
,
0
,
page
+
i
,
0
,
buff
,
PAGECACHE_PLAIN_PAGE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_
LEFT_UNLOCKED
,
0
)))
PAGECACHE_LOCK_
WRITE
,
&
page_link
.
link
)))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
if
(
lsn_korr
(
buff
)
>=
lsn
)
if
(
lsn_korr
(
buff
)
>=
lsn
)
{
{
/* Already applied */
/* Already applied */
pagecache_unlock_by_link
(
share
->
pagecache
,
page_link
.
link
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
LSN_IMPOSSIBLE
,
LSN_IMPOSSIBLE
);
continue
;
continue
;
}
}
buff
[
PAGE_TYPE_OFFSET
]
=
UNALLOCATED_PAGE
;
buff
[
PAGE_TYPE_OFFSET
]
=
UNALLOCATED_PAGE
;
...
@@ -4889,8 +4920,7 @@ uint _ma_apply_redo_purge_blocks(MARIA_HA *info,
...
@@ -4889,8 +4920,7 @@ uint _ma_apply_redo_purge_blocks(MARIA_HA *info,
if
(
pagecache_write
(
share
->
pagecache
,
if
(
pagecache_write
(
share
->
pagecache
,
&
info
->
dfile
,
page
+
i
,
0
,
&
info
->
dfile
,
page
+
i
,
0
,
buff
,
PAGECACHE_PLAIN_PAGE
,
buff
,
PAGECACHE_PLAIN_PAGE
,
PAGECACHE_LOCK_LEFT_UNLOCKED
,
PAGECACHE_LOCK_WRITE_UNLOCK
,
PAGECACHE_UNPIN
,
PAGECACHE_PIN_LEFT_UNPINNED
,
PAGECACHE_WRITE_DELAY
,
0
))
PAGECACHE_WRITE_DELAY
,
0
))
DBUG_RETURN
(
my_errno
);
DBUG_RETURN
(
my_errno
);
}
}
...
...
storage/maria/ma_loghandler.c
View file @
69c18ca5
This diff is collapsed.
Click to expand it.
storage/maria/ma_loghandler.h
View file @
69c18ca5
...
@@ -182,10 +182,14 @@ typedef struct st_translog_scanner_data
...
@@ -182,10 +182,14 @@ typedef struct st_translog_scanner_data
TRANSLOG_ADDRESS
horizon
;
TRANSLOG_ADDRESS
horizon
;
TRANSLOG_ADDRESS
last_file_page
;
/* Last page on in this file */
TRANSLOG_ADDRESS
last_file_page
;
/* Last page on in this file */
uchar
*
page
;
/* page content pointer */
uchar
*
page
;
/* page content pointer */
/* direct link on the current page or NULL if not supported/requested */
PAGECACHE_BLOCK_LINK
*
direct_link
;
/* offset of the chunk in the page */
/* offset of the chunk in the page */
translog_size_t
page_offset
;
translog_size_t
page_offset
;
/* set horizon only once at init */
/* set horizon only once at init */
my_bool
fixed_horizon
;
my_bool
fixed_horizon
;
/* try to get direct link on the page if it is possible */
my_bool
use_direct_link
;
}
TRANSLOG_SCANNER_DATA
;
}
TRANSLOG_SCANNER_DATA
;
...
@@ -245,7 +249,9 @@ extern my_bool translog_flush(LSN lsn);
...
@@ -245,7 +249,9 @@ extern my_bool translog_flush(LSN lsn);
extern
my_bool
translog_init_scanner
(
LSN
lsn
,
extern
my_bool
translog_init_scanner
(
LSN
lsn
,
my_bool
fixed_horizon
,
my_bool
fixed_horizon
,
struct
st_translog_scanner_data
*
scanner
);
struct
st_translog_scanner_data
*
scanner
,
my_bool
use_direct_link
);
extern
void
translog_destroy_scanner
(
TRANSLOG_SCANNER_DATA
*
scanner
);
extern
int
translog_read_next_record_header
(
TRANSLOG_SCANNER_DATA
*
scanner
,
extern
int
translog_read_next_record_header
(
TRANSLOG_SCANNER_DATA
*
scanner
,
TRANSLOG_HEADER_BUFFER
*
buff
);
TRANSLOG_HEADER_BUFFER
*
buff
);
...
...
storage/maria/ma_open.c
View file @
69c18ca5
...
@@ -58,7 +58,7 @@ if (pos > end_pos) \
...
@@ -58,7 +58,7 @@ if (pos > end_pos) \
** In MySQL the server will handle version issues.
** In MySQL the server will handle version issues.
******************************************************************************/
******************************************************************************/
MARIA_HA
*
_ma_test_if_reopen
(
char
*
filename
)
MARIA_HA
*
_ma_test_if_reopen
(
c
onst
c
har
*
filename
)
{
{
LIST
*
pos
;
LIST
*
pos
;
...
@@ -1001,7 +1001,9 @@ uint _ma_state_info_write(MARIA_SHARE *share, uint pWrite)
...
@@ -1001,7 +1001,9 @@ uint _ma_state_info_write(MARIA_SHARE *share, uint pWrite)
if
(
pWrite
&
4
)
if
(
pWrite
&
4
)
pthread_mutex_lock
(
&
share
->
intern_lock
);
pthread_mutex_lock
(
&
share
->
intern_lock
);
else
if
(
maria_multi_threaded
)
else
if
(
maria_multi_threaded
)
{
safe_mutex_assert_owner
(
&
share
->
intern_lock
);
safe_mutex_assert_owner
(
&
share
->
intern_lock
);
}
if
(
share
->
base
.
born_transactional
&&
translog_inited
&&
if
(
share
->
base
.
born_transactional
&&
translog_inited
&&
!
maria_in_recovery
)
!
maria_in_recovery
)
{
{
...
...
storage/maria/ma_pagecache.c
View file @
69c18ca5
This diff is collapsed.
Click to expand it.
storage/maria/ma_pagecache.h
View file @
69c18ca5
...
@@ -73,8 +73,6 @@ enum pagecache_write_mode
...
@@ -73,8 +73,6 @@ enum pagecache_write_mode
PAGECACHE_WRITE_DONE
PAGECACHE_WRITE_DONE
};
};
typedef
void
*
PAGECACHE_PAGE_LINK
;
/* file descriptor for Maria */
/* file descriptor for Maria */
typedef
struct
st_pagecache_file
typedef
struct
st_pagecache_file
{
{
...
@@ -106,25 +104,22 @@ typedef my_bool (*pagecache_disk_read_validator)(uchar *page, uchar *data);
...
@@ -106,25 +104,22 @@ typedef my_bool (*pagecache_disk_read_validator)(uchar *page, uchar *data);
typedef
struct
st_pagecache
typedef
struct
st_pagecache
{
{
my_bool
inited
;
my_bool
resize_in_flush
;
/* true during flush of resize operation */
my_bool
can_be_used
;
/* usage of cache for read/write is allowed */
uint
shift
;
/* block size = 2 ^ shift */
size_t
mem_size
;
/* specified size of the cache memory */
size_t
mem_size
;
/* specified size of the cache memory */
uint32
block_size
;
/* size of the page buffer of a cache block */
ulong
min_warm_blocks
;
/* min number of warm blocks; */
ulong
min_warm_blocks
;
/* min number of warm blocks; */
ulong
age_threshold
;
/* age threshold for hot blocks */
ulong
age_threshold
;
/* age threshold for hot blocks */
ulonglong
time
;
/* total number of block link operations */
ulonglong
time
;
/* total number of block link operations */
u
int
hash_entries
;
/* max number of entries in the hash table */
u
long
hash_entries
;
/* max number of entries in the hash table */
int
hash_links
;
/* max number of hash links */
long
hash_links
;
/* max number of hash links */
int
hash_links_used
;
/* number of hash links taken from free links pool */
long
hash_links_used
;
/* number of hash links taken from free links pool */
int
disk_blocks
;
/* max number of blocks in the cache */
long
disk_blocks
;
/* max number of blocks in the cache */
ulong
blocks_used
;
/* maximum number of concurrently used blocks */
ulong
blocks_used
;
/* maximum number of concurrently used blocks */
ulong
blocks_unused
;
/* number of currently unused blocks */
ulong
blocks_unused
;
/* number of currently unused blocks */
ulong
blocks_changed
;
/* number of currently dirty blocks */
ulong
blocks_changed
;
/* number of currently dirty blocks */
ulong
warm_blocks
;
/* number of blocks in warm sub-chain */
ulong
warm_blocks
;
/* number of blocks in warm sub-chain */
ulong
cnt_for_resize_op
;
/* counter to block resize operation */
ulong
cnt_for_resize_op
;
/* counter to block resize operation */
ulong
blocks_available
;
/* number of blocks available in the LRU chain */
ulong
blocks_available
;
/* number of blocks available in the LRU chain */
long
blocks
;
/* max number of blocks in the cache */
uint32
block_size
;
/* size of the page buffer of a cache block */
PAGECACHE_HASH_LINK
**
hash_root
;
/* arr. of entries into hash table buckets */
PAGECACHE_HASH_LINK
**
hash_root
;
/* arr. of entries into hash table buckets */
PAGECACHE_HASH_LINK
*
hash_link_root
;
/* memory for hash table links */
PAGECACHE_HASH_LINK
*
hash_link_root
;
/* memory for hash table links */
PAGECACHE_HASH_LINK
*
free_hash_list
;
/* list of free hash links */
PAGECACHE_HASH_LINK
*
free_hash_list
;
/* list of free hash links */
...
@@ -159,17 +154,20 @@ typedef struct st_pagecache
...
@@ -159,17 +154,20 @@ typedef struct st_pagecache
ulonglong
global_cache_r_requests
;
/* number of read requests (read hits) */
ulonglong
global_cache_r_requests
;
/* number of read requests (read hits) */
ulonglong
global_cache_read
;
/* number of reads from files to cache */
ulonglong
global_cache_read
;
/* number of reads from files to cache */
int
blocks
;
/* max number of blocks in the cache */
uint
shift
;
/* block size = 2 ^ shift */
my_bool
inited
;
my_bool
resize_in_flush
;
/* true during flush of resize operation */
my_bool
can_be_used
;
/* usage of cache for read/write is allowed */
my_bool
in_init
;
/* Set to 1 in MySQL during init/resize */
my_bool
in_init
;
/* Set to 1 in MySQL during init/resize */
}
PAGECACHE
;
}
PAGECACHE
;
/* The default key cache */
/* The default key cache */
extern
PAGECACHE
dflt_pagecache_var
,
*
dflt_pagecache
;
extern
PAGECACHE
dflt_pagecache_var
,
*
dflt_pagecache
;
extern
int
init_pagecache
(
PAGECACHE
*
pagecache
,
size_t
use_mem
,
extern
ulong
init_pagecache
(
PAGECACHE
*
pagecache
,
size_t
use_mem
,
uint
division_limit
,
uint
age_threshold
,
uint
division_limit
,
uint
age_threshold
,
uint
block_size
);
uint
block_size
);
extern
int
resize_pagecache
(
PAGECACHE
*
pagecache
,
extern
ulong
resize_pagecache
(
PAGECACHE
*
pagecache
,
size_t
use_mem
,
uint
division_limit
,
size_t
use_mem
,
uint
division_limit
,
uint
age_threshold
);
uint
age_threshold
);
extern
void
change_pagecache_param
(
PAGECACHE
*
pagecache
,
uint
division_limit
,
extern
void
change_pagecache_param
(
PAGECACHE
*
pagecache
,
uint
division_limit
,
...
@@ -185,7 +183,7 @@ extern uchar *pagecache_valid_read(PAGECACHE *pagecache,
...
@@ -185,7 +183,7 @@ extern uchar *pagecache_valid_read(PAGECACHE *pagecache,
uchar
*
buff
,
uchar
*
buff
,
enum
pagecache_page_type
type
,
enum
pagecache_page_type
type
,
enum
pagecache_page_lock
lock
,
enum
pagecache_page_lock
lock
,
PAGECACHE_
PAGE_LINK
*
link
,
PAGECACHE_
BLOCK_LINK
*
*
link
,
pagecache_disk_read_validator
validator
,
pagecache_disk_read_validator
validator
,
uchar
*
validator_data
);
uchar
*
validator_data
);
...
@@ -205,7 +203,7 @@ extern my_bool pagecache_write_part(PAGECACHE *pagecache,
...
@@ -205,7 +203,7 @@ extern my_bool pagecache_write_part(PAGECACHE *pagecache,
enum
pagecache_page_lock
lock
,
enum
pagecache_page_lock
lock
,
enum
pagecache_page_pin
pin
,
enum
pagecache_page_pin
pin
,
enum
pagecache_write_mode
write_mode
,
enum
pagecache_write_mode
write_mode
,
PAGECACHE_
PAGE_LINK
*
link
,
PAGECACHE_
BLOCK_LINK
*
*
link
,
uint
offset
,
uint
offset
,
uint
size
,
uint
size
,
pagecache_disk_read_validator
validator
,
pagecache_disk_read_validator
validator
,
...
@@ -218,7 +216,7 @@ extern void pagecache_unlock(PAGECACHE *pagecache,
...
@@ -218,7 +216,7 @@ extern void pagecache_unlock(PAGECACHE *pagecache,
LSN
first_REDO_LSN_for_page
,
LSN
first_REDO_LSN_for_page
,
LSN
lsn
);
LSN
lsn
);
extern
void
pagecache_unlock_by_link
(
PAGECACHE
*
pagecache
,
extern
void
pagecache_unlock_by_link
(
PAGECACHE
*
pagecache
,
PAGECACHE_
PAGE_LINK
*
lin
k
,
PAGECACHE_
BLOCK_LINK
*
bloc
k
,
enum
pagecache_page_lock
lock
,
enum
pagecache_page_lock
lock
,
enum
pagecache_page_pin
pin
,
enum
pagecache_page_pin
pin
,
LSN
first_REDO_LSN_for_page
,
LSN
first_REDO_LSN_for_page
,
...
@@ -228,7 +226,7 @@ extern void pagecache_unpin(PAGECACHE *pagecache,
...
@@ -228,7 +226,7 @@ extern void pagecache_unpin(PAGECACHE *pagecache,
pgcache_page_no_t
pageno
,
pgcache_page_no_t
pageno
,
LSN
lsn
);
LSN
lsn
);
extern
void
pagecache_unpin_by_link
(
PAGECACHE
*
pagecache
,
extern
void
pagecache_unpin_by_link
(
PAGECACHE
*
pagecache
,
PAGECACHE_
PAGE
_LINK
*
link
,
PAGECACHE_
BLOCK
_LINK
*
link
,
LSN
lsn
);
LSN
lsn
);
extern
int
flush_pagecache_blocks
(
PAGECACHE
*
keycache
,
extern
int
flush_pagecache_blocks
(
PAGECACHE
*
keycache
,
PAGECACHE_FILE
*
file
,
PAGECACHE_FILE
*
file
,
...
...
storage/maria/ma_recovery.c
View file @
69c18ca5
...
@@ -105,6 +105,7 @@ static int new_table(uint16 sid, const char *name,
...
@@ -105,6 +105,7 @@ static int new_table(uint16 sid, const char *name,
static
int
new_page
(
File
fileid
,
pgcache_page_no_t
pageid
,
LSN
rec_lsn
,
static
int
new_page
(
File
fileid
,
pgcache_page_no_t
pageid
,
LSN
rec_lsn
,
struct
st_dirty_page
*
dirty_page
);
struct
st_dirty_page
*
dirty_page
);
static
int
close_all_tables
(
void
);
static
int
close_all_tables
(
void
);
static
my_bool
close_one_table
(
const
char
*
name
,
LSN
addr
);
static
void
print_redo_phase_progress
(
TRANSLOG_ADDRESS
addr
);
static
void
print_redo_phase_progress
(
TRANSLOG_ADDRESS
addr
);
/** @brief global [out] buffer for translog_read_record(); never shrinks */
/** @brief global [out] buffer for translog_read_record(); never shrinks */
...
@@ -418,6 +419,8 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -418,6 +419,8 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
uint
flags
;
uint
flags
;
int
error
=
1
,
create_mode
=
O_RDWR
|
O_TRUNC
;
int
error
=
1
,
create_mode
=
O_RDWR
|
O_TRUNC
;
MARIA_HA
*
info
=
NULL
;
MARIA_HA
*
info
=
NULL
;
uint
kfile_size_before_extension
,
keystart
;
if
(
skip_DDLs
)
if
(
skip_DDLs
)
{
{
tprint
(
tracef
,
"we skip DDLs
\n
"
);
tprint
(
tracef
,
"we skip DDLs
\n
"
);
...
@@ -434,6 +437,12 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -434,6 +437,12 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
}
}
name
=
log_record_buffer
.
str
;
name
=
log_record_buffer
.
str
;
tprint
(
tracef
,
"Table '%s'"
,
name
);
tprint
(
tracef
,
"Table '%s'"
,
name
);
if
(
close_one_table
(
name
,
rec
->
lsn
))
{
tprint
(
tracef
,
" got error %d on close
\n
"
,
my_errno
);
ALERT_USER
();
goto
end
;
}
/* we try hard to get create_rename_lsn, to avoid mistakes if possible */
/* we try hard to get create_rename_lsn, to avoid mistakes if possible */
info
=
maria_open
(
name
,
O_RDONLY
,
HA_OPEN_FOR_REPAIR
);
info
=
maria_open
(
name
,
O_RDONLY
,
HA_OPEN_FOR_REPAIR
);
if
(
info
)
if
(
info
)
...
@@ -477,7 +486,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -477,7 +486,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
info
=
NULL
;
info
=
NULL
;
}
}
else
/* one or two files absent, or header corrupted... */
else
/* one or two files absent, or header corrupted... */
tprint
(
tracef
,
"can't be opened, probably does not exist"
);
tprint
(
tracef
,
"
can't be opened, probably does not exist"
);
/* if does not exist, or is older, overwrite it */
/* if does not exist, or is older, overwrite it */
/** @todo symlinks */
/** @todo symlinks */
ptr
=
name
+
strlen
(
name
)
+
1
;
ptr
=
name
+
strlen
(
name
)
+
1
;
...
@@ -493,13 +502,13 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -493,13 +502,13 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
if
((
kfile
=
my_create_with_symlink
(
linkname_ptr
,
filename
,
0
,
create_mode
,
if
((
kfile
=
my_create_with_symlink
(
linkname_ptr
,
filename
,
0
,
create_mode
,
MYF
(
MY_WME
|
create_flag
)))
<
0
)
MYF
(
MY_WME
|
create_flag
)))
<
0
)
{
{
tprint
(
tracef
,
"Failed to create index file
\n
"
);
tprint
(
tracef
,
"
Failed to create index file
\n
"
);
goto
end
;
goto
end
;
}
}
ptr
++
;
ptr
++
;
uint
kfile_size_before_extension
=
uint2korr
(
ptr
);
kfile_size_before_extension
=
uint2korr
(
ptr
);
ptr
+=
2
;
ptr
+=
2
;
uint
keystart
=
uint2korr
(
ptr
);
keystart
=
uint2korr
(
ptr
);
ptr
+=
2
;
ptr
+=
2
;
/* set create_rename_lsn (for maria_read_log to be idempotent) */
/* set create_rename_lsn (for maria_read_log to be idempotent) */
lsn_store
(
ptr
+
sizeof
(
info
->
s
->
state
.
header
)
+
2
,
rec
->
lsn
);
lsn_store
(
ptr
+
sizeof
(
info
->
s
->
state
.
header
)
+
2
,
rec
->
lsn
);
...
@@ -510,7 +519,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -510,7 +519,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
kfile_size_before_extension
,
0
,
MYF
(
MY_NABP
|
MY_WME
))
||
kfile_size_before_extension
,
0
,
MYF
(
MY_NABP
|
MY_WME
))
||
my_chsize
(
kfile
,
keystart
,
0
,
MYF
(
MY_WME
)))
my_chsize
(
kfile
,
keystart
,
0
,
MYF
(
MY_WME
)))
{
{
tprint
(
tracef
,
"Failed to write to index file
\n
"
);
tprint
(
tracef
,
"
Failed to write to index file
\n
"
);
goto
end
;
goto
end
;
}
}
if
(
!
(
flags
&
HA_DONT_TOUCH_DATA
))
if
(
!
(
flags
&
HA_DONT_TOUCH_DATA
))
...
@@ -524,7 +533,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -524,7 +533,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
MYF
(
MY_WME
|
create_flag
)))
<
0
)
||
MYF
(
MY_WME
|
create_flag
)))
<
0
)
||
my_close
(
dfile
,
MYF
(
MY_WME
)))
my_close
(
dfile
,
MYF
(
MY_WME
)))
{
{
tprint
(
tracef
,
"Failed to create data file
\n
"
);
tprint
(
tracef
,
"
Failed to create data file
\n
"
);
goto
end
;
goto
end
;
}
}
/*
/*
...
@@ -536,7 +545,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
...
@@ -536,7 +545,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
if
(((
info
=
maria_open
(
name
,
O_RDONLY
,
0
))
==
NULL
)
||
if
(((
info
=
maria_open
(
name
,
O_RDONLY
,
0
))
==
NULL
)
||
_ma_initialize_data_file
(
info
->
s
,
info
->
dfile
.
file
))
_ma_initialize_data_file
(
info
->
s
,
info
->
dfile
.
file
))
{
{
tprint
(
tracef
,
"Failed to open new table or write to data file
\n
"
);
tprint
(
tracef
,
"
Failed to open new table or write to data file
\n
"
);
goto
end
;
goto
end
;
}
}
}
}
...
@@ -1439,6 +1448,11 @@ prototype_undo_exec_hook(UNDO_ROW_UPDATE)
...
@@ -1439,6 +1448,11 @@ prototype_undo_exec_hook(UNDO_ROW_UPDATE)
static
int
run_redo_phase
(
LSN
lsn
,
my_bool
apply
)
static
int
run_redo_phase
(
LSN
lsn
,
my_bool
apply
)
{
{
TRANSLOG_HEADER_BUFFER
rec
;
struct
st_translog_scanner_data
scanner
;
int
len
;
uint
i
;
/* install hooks for execution */
/* install hooks for execution */
#define install_redo_exec_hook(R) \
#define install_redo_exec_hook(R) \
log_record_type_descriptor[LOGREC_ ## R].record_execute_in_redo_phase= \
log_record_type_descriptor[LOGREC_ ## R].record_execute_in_redo_phase= \
...
@@ -1470,8 +1484,6 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1470,8 +1484,6 @@ static int run_redo_phase(LSN lsn, my_bool apply)
current_group_end_lsn
=
LSN_IMPOSSIBLE
;
current_group_end_lsn
=
LSN_IMPOSSIBLE
;
TRANSLOG_HEADER_BUFFER
rec
;
if
(
unlikely
(
lsn
==
LSN_IMPOSSIBLE
||
lsn
==
translog_get_horizon
()))
if
(
unlikely
(
lsn
==
LSN_IMPOSSIBLE
||
lsn
==
translog_get_horizon
()))
{
{
tprint
(
tracef
,
"checkpoint address refers to the log end log or "
tprint
(
tracef
,
"checkpoint address refers to the log end log or "
...
@@ -1479,7 +1491,7 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1479,7 +1491,7 @@ static int run_redo_phase(LSN lsn, my_bool apply)
return
0
;
return
0
;
}
}
int
len
=
translog_read_record_header
(
lsn
,
&
rec
);
len
=
translog_read_record_header
(
lsn
,
&
rec
);
/** @todo EOF should be detected */
/** @todo EOF should be detected */
if
(
len
==
RECHEADER_READ_ERROR
)
if
(
len
==
RECHEADER_READ_ERROR
)
...
@@ -1487,13 +1499,11 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1487,13 +1499,11 @@ static int run_redo_phase(LSN lsn, my_bool apply)
tprint
(
tracef
,
"Failed to read header of the first record.
\n
"
);
tprint
(
tracef
,
"Failed to read header of the first record.
\n
"
);
return
1
;
return
1
;
}
}
struct
st_translog_scanner_data
scanner
;
if
(
translog_init_scanner
(
lsn
,
1
,
&
scanner
,
1
))
if
(
translog_init_scanner
(
lsn
,
1
,
&
scanner
))
{
{
tprint
(
tracef
,
"Scanner init failed
\n
"
);
tprint
(
tracef
,
"Scanner init failed
\n
"
);
return
1
;
return
1
;
}
}
uint
i
;
for
(
i
=
1
;;
i
++
)
for
(
i
=
1
;;
i
++
)
{
{
uint16
sid
=
rec
.
short_trid
;
uint16
sid
=
rec
.
short_trid
;
...
@@ -1522,24 +1532,25 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1522,24 +1532,25 @@ static int run_redo_phase(LSN lsn, my_bool apply)
}
}
else
else
{
{
struct
st_translog_scanner_data
scanner2
;
TRANSLOG_HEADER_BUFFER
rec2
;
/*
/*
There is a complete group for this transaction, containing more
There is a complete group for this transaction, containing more
than this event.
than this event.
*/
*/
tprint
(
tracef
,
" ends a group:
\n
"
);
tprint
(
tracef
,
" ends a group:
\n
"
);
struct
st_translog_scanner_data
scanner2
;
TRANSLOG_HEADER_BUFFER
rec2
;
len
=
len
=
translog_read_record_header
(
all_active_trans
[
sid
].
group_start_lsn
,
&
rec2
);
translog_read_record_header
(
all_active_trans
[
sid
].
group_start_lsn
,
&
rec2
);
if
(
len
<
0
)
/* EOF or error */
if
(
len
<
0
)
/* EOF or error */
{
{
tprint
(
tracef
,
"Cannot find record where it should be
\n
"
);
tprint
(
tracef
,
"Cannot find record where it should be
\n
"
);
return
1
;
goto
err
;
}
}
if
(
translog_init_scanner
(
rec2
.
lsn
,
1
,
&
scanner2
))
if
(
translog_init_scanner
(
rec2
.
lsn
,
1
,
&
scanner2
,
1
))
{
{
tprint
(
tracef
,
"Scanner2 init failed
\n
"
);
tprint
(
tracef
,
"Scanner2 init failed
\n
"
);
return
1
;
goto
err
;
}
}
current_group_end_lsn
=
rec
.
lsn
;
current_group_end_lsn
=
rec
.
lsn
;
do
do
...
@@ -1549,13 +1560,16 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1549,13 +1560,16 @@ static int run_redo_phase(LSN lsn, my_bool apply)
const
LOG_DESC
*
log_desc2
=
&
log_record_type_descriptor
[
rec2
.
type
];
const
LOG_DESC
*
log_desc2
=
&
log_record_type_descriptor
[
rec2
.
type
];
display_record_position
(
log_desc2
,
&
rec2
,
0
);
display_record_position
(
log_desc2
,
&
rec2
,
0
);
if
(
apply
&&
display_and_apply_record
(
log_desc2
,
&
rec2
))
if
(
apply
&&
display_and_apply_record
(
log_desc2
,
&
rec2
))
return
1
;
{
translog_destroy_scanner
(
&
scanner2
);
goto
err
;
}
}
}
len
=
translog_read_next_record_header
(
&
scanner2
,
&
rec2
);
len
=
translog_read_next_record_header
(
&
scanner2
,
&
rec2
);
if
(
len
<
0
)
/* EOF or error */
if
(
len
<
0
)
/* EOF or error */
{
{
tprint
(
tracef
,
"Cannot find record where it should be
\n
"
);
tprint
(
tracef
,
"Cannot find record where it should be
\n
"
);
return
1
;
goto
err
;
}
}
}
}
while
(
rec2
.
lsn
<
rec
.
lsn
);
while
(
rec2
.
lsn
<
rec
.
lsn
);
...
@@ -1564,10 +1578,11 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1564,10 +1578,11 @@ static int run_redo_phase(LSN lsn, my_bool apply)
all_active_trans
[
sid
].
group_start_lsn
=
LSN_IMPOSSIBLE
;
all_active_trans
[
sid
].
group_start_lsn
=
LSN_IMPOSSIBLE
;
current_group_end_lsn
=
LSN_IMPOSSIBLE
;
/* for debugging */
current_group_end_lsn
=
LSN_IMPOSSIBLE
;
/* for debugging */
display_record_position
(
log_desc
,
&
rec
,
0
);
display_record_position
(
log_desc
,
&
rec
,
0
);
translog_destroy_scanner
(
&
scanner2
);
}
}
}
}
if
(
apply
&&
display_and_apply_record
(
log_desc
,
&
rec
))
if
(
apply
&&
display_and_apply_record
(
log_desc
,
&
rec
))
return
1
;
goto
err
;
}
}
else
/* record does not end group */
else
/* record does not end group */
{
{
...
@@ -1588,13 +1603,18 @@ static int run_redo_phase(LSN lsn, my_bool apply)
...
@@ -1588,13 +1603,18 @@ static int run_redo_phase(LSN lsn, my_bool apply)
break
;
break
;
case
RECHEADER_READ_ERROR
:
case
RECHEADER_READ_ERROR
:
tprint
(
tracef
,
"Error reading log
\n
"
);
tprint
(
tracef
,
"Error reading log
\n
"
);
return
1
;
goto
err
;
}
}
break
;
break
;
}
}
}
}
translog_destroy_scanner
(
&
scanner
);
translog_free_record_header
(
&
rec
);
translog_free_record_header
(
&
rec
);
return
0
;
return
0
;
err:
translog_destroy_scanner
(
&
scanner
);
return
1
;
}
}
...
@@ -1610,6 +1630,7 @@ static uint end_of_redo_phase(my_bool prepare_for_undo_phase)
...
@@ -1610,6 +1630,7 @@ static uint end_of_redo_phase(my_bool prepare_for_undo_phase)
{
{
uint
sid
,
unfinished
=
0
;
uint
sid
,
unfinished
=
0
;
char
llbuf
[
22
];
char
llbuf
[
22
];
LSN
addr
;
hash_free
(
&
all_dirty_pages
);
hash_free
(
&
all_dirty_pages
);
/*
/*
...
@@ -1670,7 +1691,7 @@ static uint end_of_redo_phase(my_bool prepare_for_undo_phase)
...
@@ -1670,7 +1691,7 @@ static uint end_of_redo_phase(my_bool prepare_for_undo_phase)
The UNDO phase uses some normal run-time code of ROLLBACK: generates log
The UNDO phase uses some normal run-time code of ROLLBACK: generates log
records, etc; prepare tables for that
records, etc; prepare tables for that
*/
*/
LSN
addr
=
translog_get_horizon
();
addr
=
translog_get_horizon
();
for
(
sid
=
0
;
sid
<=
SHARE_ID_MAX
;
sid
++
)
for
(
sid
=
0
;
sid
<=
SHARE_ID_MAX
;
sid
++
)
{
{
MARIA_HA
*
info
=
all_tables
[
sid
].
info
;
MARIA_HA
*
info
=
all_tables
[
sid
].
info
;
...
@@ -2073,6 +2094,42 @@ end:
...
@@ -2073,6 +2094,42 @@ end:
return
error
;
return
error
;
}
}
/* Close one table during redo phase */
static
my_bool
close_one_table
(
const
char
*
open_name
,
LSN
addr
)
{
my_bool
res
=
0
;
LIST
*
pos
;
/* There are no other threads using the tables, so we don't need any locks */
for
(
pos
=
maria_open_list
;
pos
;)
{
MARIA_HA
*
info
=
(
MARIA_HA
*
)
pos
->
data
;
MARIA_SHARE
*
share
=
info
->
s
;
pos
=
pos
->
next
;
if
(
!
strcmp
(
share
->
open_file_name
,
open_name
))
{
struct
st_table_for_recovery
*
internal_table
,
*
end
;
for
(
internal_table
=
all_tables
,
end
=
internal_table
+
SHARE_ID_MAX
+
1
;
internal_table
<
end
;
internal_table
++
)
{
if
(
internal_table
->
info
==
info
)
{
internal_table
->
info
=
0
;
break
;
}
}
prepare_table_for_close
(
info
,
addr
);
if
(
maria_close
(
info
))
res
=
1
;
}
}
return
res
;
}
static
void
print_redo_phase_progress
(
TRANSLOG_ADDRESS
addr
)
static
void
print_redo_phase_progress
(
TRANSLOG_ADDRESS
addr
)
{
{
static
int
end_logno
=
FILENO_IMPOSSIBLE
,
end_offset
,
percentage_printed
=
0
;
static
int
end_logno
=
FILENO_IMPOSSIBLE
,
end_offset
,
percentage_printed
=
0
;
...
...
storage/maria/maria_chk.c
View file @
69c18ca5
...
@@ -154,7 +154,7 @@ int main(int argc, char **argv)
...
@@ -154,7 +154,7 @@ int main(int argc, char **argv)
enum
options_mc
{
enum
options_mc
{
OPT_CHARSETS_DIR
=
256
,
OPT_SET_COLLATION
,
OPT_START_CHECK_POS
,
OPT_CHARSETS_DIR
=
256
,
OPT_SET_COLLATION
,
OPT_START_CHECK_POS
,
OPT_CORRECT_CHECKSUM
,
OPT_
KEY
_BUFFER_SIZE
,
OPT_CORRECT_CHECKSUM
,
OPT_
PAGE
_BUFFER_SIZE
,
OPT_KEY_CACHE_BLOCK_SIZE
,
OPT_MARIA_BLOCK_SIZE
,
OPT_KEY_CACHE_BLOCK_SIZE
,
OPT_MARIA_BLOCK_SIZE
,
OPT_READ_BUFFER_SIZE
,
OPT_WRITE_BUFFER_SIZE
,
OPT_SORT_BUFFER_SIZE
,
OPT_READ_BUFFER_SIZE
,
OPT_WRITE_BUFFER_SIZE
,
OPT_SORT_BUFFER_SIZE
,
OPT_SORT_KEY_BLOCKS
,
OPT_DECODE_BITS
,
OPT_FT_MIN_WORD_LEN
,
OPT_SORT_KEY_BLOCKS
,
OPT_DECODE_BITS
,
OPT_FT_MIN_WORD_LEN
,
...
@@ -296,7 +296,7 @@ static struct my_option my_long_options[] =
...
@@ -296,7 +296,7 @@ static struct my_option my_long_options[] =
{
"wait"
,
'w'
,
{
"wait"
,
'w'
,
"Wait if table is locked."
,
"Wait if table is locked."
,
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"
key_buffer_size"
,
OPT_KEY
_BUFFER_SIZE
,
""
,
{
"
page_buffer_size"
,
OPT_PAGE
_BUFFER_SIZE
,
""
,
(
uchar
**
)
&
check_param
.
use_buffers
,
(
uchar
**
)
&
check_param
.
use_buffers
,
0
,
(
uchar
**
)
&
check_param
.
use_buffers
,
(
uchar
**
)
&
check_param
.
use_buffers
,
0
,
GET_ULONG
,
REQUIRED_ARG
,
(
long
)
USE_BUFFER_INIT
,
(
long
)
MALLOC_OVERHEAD
,
GET_ULONG
,
REQUIRED_ARG
,
(
long
)
USE_BUFFER_INIT
,
(
long
)
MALLOC_OVERHEAD
,
(
long
)
~
0L
,
(
long
)
MALLOC_OVERHEAD
,
(
long
)
IO_SIZE
,
0
},
(
long
)
~
0L
,
(
long
)
MALLOC_OVERHEAD
,
(
long
)
IO_SIZE
,
0
},
...
...
storage/maria/maria_def.h
View file @
69c18ca5
...
@@ -632,7 +632,7 @@ typedef struct st_maria_s_param
...
@@ -632,7 +632,7 @@ typedef struct st_maria_s_param
/* Used to store reference to pinned page */
/* Used to store reference to pinned page */
typedef
struct
st_pinned_page
typedef
struct
st_pinned_page
{
{
PAGECACHE_
PAGE_LINK
link
;
PAGECACHE_
BLOCK_LINK
*
link
;
enum
pagecache_page_lock
unlock
;
enum
pagecache_page_lock
unlock
;
}
MARIA_PINNED_PAGE
;
}
MARIA_PINNED_PAGE
;
...
@@ -842,7 +842,7 @@ typedef struct st_maria_block_info
...
@@ -842,7 +842,7 @@ typedef struct st_maria_block_info
#define UPDATE_AUTO_INC 8
#define UPDATE_AUTO_INC 8
#define UPDATE_OPEN_COUNT 16
#define UPDATE_OPEN_COUNT 16
#define USE_BUFFER_INIT (((1024L*
512L-MALLOC_OVERHEAD)/IO_SIZE)*IO_SIZE
)
#define USE_BUFFER_INIT (((1024L*
1024L*10-MALLOC_OVERHEAD)/8192)*8192
)
#define READ_BUFFER_INIT (1024L*256L-MALLOC_OVERHEAD)
#define READ_BUFFER_INIT (1024L*256L-MALLOC_OVERHEAD)
#define SORT_BUFFER_INIT (2048L*1024L-MALLOC_OVERHEAD)
#define SORT_BUFFER_INIT (2048L*1024L-MALLOC_OVERHEAD)
#define MIN_SORT_BUFFER (4096-MALLOC_OVERHEAD)
#define MIN_SORT_BUFFER (4096-MALLOC_OVERHEAD)
...
@@ -906,7 +906,7 @@ my_bool _ma_check_status(void *param);
...
@@ -906,7 +906,7 @@ my_bool _ma_check_status(void *param);
void
_ma_reset_status
(
MARIA_HA
*
maria
);
void
_ma_reset_status
(
MARIA_HA
*
maria
);
#include "ma_commit.h"
#include "ma_commit.h"
extern
MARIA_HA
*
_ma_test_if_reopen
(
char
*
filename
);
extern
MARIA_HA
*
_ma_test_if_reopen
(
c
onst
c
har
*
filename
);
my_bool
_ma_check_table_is_closed
(
const
char
*
name
,
const
char
*
where
);
my_bool
_ma_check_table_is_closed
(
const
char
*
name
,
const
char
*
where
);
int
_ma_open_datafile
(
MARIA_HA
*
info
,
MARIA_SHARE
*
share
,
File
file_to_dup
);
int
_ma_open_datafile
(
MARIA_HA
*
info
,
MARIA_SHARE
*
share
,
File
file_to_dup
);
int
_ma_open_keyfile
(
MARIA_SHARE
*
share
);
int
_ma_open_keyfile
(
MARIA_SHARE
*
share
);
...
...
storage/maria/maria_read_log.c
View file @
69c18ca5
...
@@ -17,7 +17,6 @@
...
@@ -17,7 +17,6 @@
#include "ma_recovery.h"
#include "ma_recovery.h"
#include <my_getopt.h>
#include <my_getopt.h>
#define PCACHE_SIZE (1024*1024*10)
#define LOG_FLAGS 0
#define LOG_FLAGS 0
#define LOG_FILE_SIZE (1024L*1024L)
#define LOG_FILE_SIZE (1024L*1024L)
...
@@ -30,7 +29,8 @@ const char *default_dbug_option= "d:t:i:O,\\maria_read_log.trace";
...
@@ -30,7 +29,8 @@ const char *default_dbug_option= "d:t:i:O,\\maria_read_log.trace";
const
char
*
default_dbug_option
=
"d:t:i:o,/tmp/maria_read_log.trace"
;
const
char
*
default_dbug_option
=
"d:t:i:o,/tmp/maria_read_log.trace"
;
#endif
#endif
#endif
/* DBUG_OFF */
#endif
/* DBUG_OFF */
static
my_bool
opt_only_display
,
opt_display_and_apply
;
static
my_bool
opt_only_display
,
opt_apply
,
opt_apply_undo
,
opt_silent
;
static
ulong
opt_page_buffer_size
;
int
main
(
int
argc
,
char
**
argv
)
int
main
(
int
argc
,
char
**
argv
)
{
{
...
@@ -63,7 +63,7 @@ int main(int argc, char **argv)
...
@@ -63,7 +63,7 @@ int main(int argc, char **argv)
}
}
/* same page cache for log and data; assumes same page size... */
/* same page cache for log and data; assumes same page size... */
DBUG_ASSERT
(
maria_block_size
==
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
maria_block_size
==
TRANSLOG_PAGE_SIZE
);
if
(
init_pagecache
(
maria_pagecache
,
PCACHE_SIZE
,
0
,
0
,
if
(
init_pagecache
(
maria_pagecache
,
opt_page_buffer_size
,
0
,
0
,
TRANSLOG_PAGE_SIZE
)
==
0
)
TRANSLOG_PAGE_SIZE
)
==
0
)
{
{
fprintf
(
stderr
,
"Got error in init_pagecache() (errno: %d)
\n
"
,
errno
);
fprintf
(
stderr
,
"Got error in init_pagecache() (errno: %d)
\n
"
,
errno
);
...
@@ -100,8 +100,8 @@ int main(int argc, char **argv)
...
@@ -100,8 +100,8 @@ int main(int argc, char **argv)
LSN_IN_PARTS
(
lsn
));
LSN_IN_PARTS
(
lsn
));
fprintf
(
stdout
,
"TRACE of the last maria_read_log
\n
"
);
fprintf
(
stdout
,
"TRACE of the last maria_read_log
\n
"
);
if
(
maria_apply_log
(
lsn
,
opt_
display_and_apply
,
stdout
,
if
(
maria_apply_log
(
lsn
,
opt_
apply
,
opt_silent
?
NULL
:
stdout
,
opt_
display_and_apply
,
FALSE
))
opt_
apply_undo
,
FALSE
))
goto
err
;
goto
err
;
fprintf
(
stdout
,
"%s: SUCCESS
\n
"
,
my_progname
);
fprintf
(
stdout
,
"%s: SUCCESS
\n
"
,
my_progname
);
...
@@ -121,19 +121,32 @@ end:
...
@@ -121,19 +121,32 @@ end:
static
struct
my_option
my_long_options
[]
=
static
struct
my_option
my_long_options
[]
=
{
{
{
"apply"
,
'a'
,
"Apply log to tables. Will display a lot of information if not run with --silent"
,
(
uchar
**
)
&
opt_apply
,
(
uchar
**
)
&
opt_apply
,
0
,
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
#ifndef DBUG_OFF
{
"debug"
,
'#'
,
"Output debug log. Often the argument is 'd:t:o,filename'."
,
0
,
0
,
0
,
GET_STR
,
OPT_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
#endif
{
"help"
,
'?'
,
"Display this help and exit."
,
{
"help"
,
'?'
,
"Display this help and exit."
,
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"only-display"
,
'o'
,
"display brief info about records's header"
,
{
"only-display"
,
'o'
,
"display brief info about records's header"
,
(
uchar
**
)
&
opt_only_display
,
(
uchar
**
)
&
opt_only_display
,
0
,
GET_BOOL
,
(
uchar
**
)
&
opt_only_display
,
(
uchar
**
)
&
opt_only_display
,
0
,
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"display-and-apply"
,
'a'
,
{
"page_buffer_size"
,
'P'
,
""
,
"like --only-display but displays more info and modifies tables"
,
(
uchar
**
)
&
opt_page_buffer_size
,
(
uchar
**
)
&
opt_page_buffer_size
,
0
,
(
uchar
**
)
&
opt_display_and_apply
,
(
uchar
**
)
&
opt_display_and_apply
,
0
,
GET_ULONG
,
REQUIRED_ARG
,
(
long
)
USE_BUFFER_INIT
,
(
long
)
MALLOC_OVERHEAD
,
(
long
)
~
(
ulong
)
0
,
(
long
)
MALLOC_OVERHEAD
,
(
long
)
IO_SIZE
,
0
},
{
"silent"
,
's'
,
"Print less information during apply/undo phase"
,
(
uchar
**
)
&
opt_silent
,
(
uchar
**
)
&
opt_silent
,
0
,
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
#ifndef DBUG_OFF
{
"undo"
,
'u'
,
"Apply undos to tables. (disable with --disable-undo)"
,
{
"debug"
,
'#'
,
"Output debug log. Often this is 'd:t:o,filename'."
,
(
uchar
**
)
&
opt_apply_undo
,
(
uchar
**
)
&
opt_apply_undo
,
0
,
0
,
0
,
0
,
GET_STR
,
OPT_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
GET_BOOL
,
NO_ARG
,
1
,
0
,
0
,
0
,
0
,
0
},
#endif
{
"version"
,
'V'
,
"Print version and exit."
,
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
0
,
0
,
0
,
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
}
{
0
,
0
,
0
,
0
,
0
,
0
,
GET_NO_ARG
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
}
};
};
...
@@ -141,7 +154,7 @@ static struct my_option my_long_options[] =
...
@@ -141,7 +154,7 @@ static struct my_option my_long_options[] =
static
void
print_version
(
void
)
static
void
print_version
(
void
)
{
{
VOID
(
printf
(
"%s Ver 1.
0
for %s on %s
\n
"
,
VOID
(
printf
(
"%s Ver 1.
1
for %s on %s
\n
"
,
my_progname
,
SYSTEM_TYPE
,
MACHINE_TYPE
));
my_progname
,
SYSTEM_TYPE
,
MACHINE_TYPE
));
NETWARE_SET_SCREEN_MODE
(
1
);
NETWARE_SET_SCREEN_MODE
(
1
);
}
}
...
@@ -174,6 +187,9 @@ get_one_option(int optid __attribute__((unused)),
...
@@ -174,6 +187,9 @@ get_one_option(int optid __attribute__((unused)),
case
'?'
:
case
'?'
:
usage
();
usage
();
exit
(
0
);
exit
(
0
);
case
'V'
:
print_version
();
exit
(
0
);
#ifndef DBUG_OFF
#ifndef DBUG_OFF
case
'#'
:
case
'#'
:
DBUG_SET_INITIAL
(
argument
?
argument
:
default_dbug_option
);
DBUG_SET_INITIAL
(
argument
?
argument
:
default_dbug_option
);
...
@@ -192,7 +208,10 @@ static void get_options(int *argc,char ***argv)
...
@@ -192,7 +208,10 @@ static void get_options(int *argc,char ***argv)
if
((
ho_error
=
handle_options
(
argc
,
argv
,
my_long_options
,
get_one_option
)))
if
((
ho_error
=
handle_options
(
argc
,
argv
,
my_long_options
,
get_one_option
)))
exit
(
ho_error
);
exit
(
ho_error
);
if
((
opt_only_display
+
opt_display_and_apply
)
!=
1
)
if
(
opt_apply_undo
)
opt_apply
=
1
;
if
((
opt_only_display
+
opt_apply
)
!=
1
)
{
{
usage
();
usage
();
exit
(
1
);
exit
(
1
);
...
...
storage/maria/unittest/ma_control_file-t.c
View file @
69c18ca5
...
@@ -407,7 +407,7 @@ static void version()
...
@@ -407,7 +407,7 @@ static void version()
static
my_bool
static
my_bool
get_one_option
(
int
optid
,
const
struct
my_option
*
opt
__attribute__
((
unused
)),
get_one_option
(
int
optid
,
const
struct
my_option
*
opt
__attribute__
((
unused
)),
char
*
argument
)
char
*
argument
__attribute__
((
unused
))
)
{
{
switch
(
optid
)
{
switch
(
optid
)
{
case
'V'
:
case
'V'
:
...
...
storage/maria/unittest/ma_test_loghandler-t.c
View file @
69c18ca5
...
@@ -363,7 +363,7 @@ int main(int argc __attribute__((unused)), char *argv[])
...
@@ -363,7 +363,7 @@ int main(int argc __attribute__((unused)), char *argv[])
read_ok
(
&
rec
);
read_ok
(
&
rec
);
translog_free_record_header
(
&
rec
);
translog_free_record_header
(
&
rec
);
lsn
=
first_lsn
;
lsn
=
first_lsn
;
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
))
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
,
0
))
{
{
fprintf
(
stderr
,
"scanner init failed
\n
"
);
fprintf
(
stderr
,
"scanner init failed
\n
"
);
goto
err
;
goto
err
;
...
...
storage/maria/unittest/ma_test_loghandler_multigroup-t.c
View file @
69c18ca5
...
@@ -378,7 +378,7 @@ int main(int argc __attribute__((unused)), char *argv[])
...
@@ -378,7 +378,7 @@ int main(int argc __attribute__((unused)), char *argv[])
ok
(
1
,
"read record"
);
ok
(
1
,
"read record"
);
translog_free_record_header
(
&
rec
);
translog_free_record_header
(
&
rec
);
lsn
=
first_lsn
;
lsn
=
first_lsn
;
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
))
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
,
0
))
{
{
fprintf
(
stderr
,
"scanner init failed
\n
"
);
fprintf
(
stderr
,
"scanner init failed
\n
"
);
goto
err
;
goto
err
;
...
...
storage/maria/unittest/ma_test_loghandler_multithread-t.c
View file @
69c18ca5
...
@@ -373,7 +373,7 @@ int main(int argc __attribute__((unused)),
...
@@ -373,7 +373,7 @@ int main(int argc __attribute__((unused)),
bzero
(
indeces
,
sizeof
(
indeces
));
bzero
(
indeces
,
sizeof
(
indeces
));
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
))
if
(
translog_init_scanner
(
first_lsn
,
1
,
&
scanner
,
0
))
{
{
fprintf
(
stderr
,
"scanner init failed
\n
"
);
fprintf
(
stderr
,
"scanner init failed
\n
"
);
goto
err
;
goto
err
;
...
...
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