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
9f5293de
Commit
9f5293de
authored
Sep 19, 2013
by
Rich Prohaska
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
#81 cleanup thread variables
parent
2ec07a29
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
243 additions
and
267 deletions
+243
-267
storage/tokudb/ha_tokudb.cc
storage/tokudb/ha_tokudb.cc
+0
-10
storage/tokudb/ha_tokudb_admin.cc
storage/tokudb/ha_tokudb_admin.cc
+1
-1
storage/tokudb/hatoku_hton.cc
storage/tokudb/hatoku_hton.cc
+0
-239
storage/tokudb/hatoku_hton.h
storage/tokudb/hatoku_hton.h
+242
-17
No files found.
storage/tokudb/ha_tokudb.cc
View file @
9f5293de
...
...
@@ -8144,16 +8144,6 @@ void ha_tokudb::print_error(int error, myf errflag) {
if
(
error
==
HA_ALTER_ERROR
)
{
error
=
HA_ERR_UNSUPPORTED
;
}
#endif
// TODO: should rename debug code to something better
// just reusing this so that tests don' start complaining
#if MYSQL_VERSION_ID < 50500
if
((
tokudb_debug
&
TOKUDB_DEBUG_HIDE_DDL_LOCK_ERRORS
)
==
0
)
{
THD
*
thd
=
ha_thd
();
if
(
get_log_client_errors
(
thd
))
{
sql_print_error
(
"query
\"
%s
\"
returned handler error %d"
,
thd
->
query_string
.
str
,
error
);
}
}
#endif
handler
::
print_error
(
error
,
errflag
);
}
...
...
storage/tokudb/ha_tokudb_admin.cc
View file @
9f5293de
...
...
@@ -106,7 +106,7 @@ static int analyze_progress(void *v_extra, uint64_t rows) {
return
ER_ABORTING_CONNECTION
;
time_t
t_now
=
time
(
0
);
time_t
t_limit
=
get_analyze_time
(
thd
);
time_t
t_limit
=
THDVAR
(
thd
,
analyze_time
);
time_t
t_start
=
extra
->
t_start
;
if
(
t_limit
>
0
&&
t_now
-
t_start
>
t_limit
)
return
ETIME
;
...
...
storage/tokudb/hatoku_hton.cc
View file @
9f5293de
...
...
@@ -132,188 +132,6 @@ static uchar *tokudb_get_key(TOKUDB_SHARE * share, size_t * length, my_bool not_
static
handler
*
tokudb_create_handler
(
handlerton
*
hton
,
TABLE_SHARE
*
table
,
MEM_ROOT
*
mem_root
);
static
MYSQL_THDVAR_BOOL
(
commit_sync
,
PLUGIN_VAR_THDLOCAL
,
"sync on txn commit"
,
/* check */
NULL
,
/* update */
NULL
,
/* default*/
true
);
static
MYSQL_THDVAR_UINT
(
pk_insert_mode
,
0
,
"set the primary key insert mode"
,
NULL
,
NULL
,
1
,
// default
0
,
// min?
2
,
// max
1
// blocksize
);
static
MYSQL_THDVAR_BOOL
(
load_save_space
,
0
,
"if on, intial loads are slower but take less space"
,
NULL
,
NULL
,
false
);
static
MYSQL_THDVAR_BOOL
(
disable_slow_alter
,
0
,
"if on, alter tables that require copy are disabled"
,
NULL
,
NULL
,
false
);
static
MYSQL_THDVAR_BOOL
(
disable_hot_alter
,
0
,
"if on, hot alter table is disabled"
,
NULL
,
NULL
,
false
);
static
MYSQL_THDVAR_BOOL
(
create_index_online
,
0
,
"if on, create index done online"
,
NULL
,
NULL
,
true
);
static
MYSQL_THDVAR_BOOL
(
disable_prefetching
,
0
,
"if on, prefetching disabled"
,
NULL
,
NULL
,
false
);
static
MYSQL_THDVAR_BOOL
(
prelock_empty
,
0
,
"Tokudb Prelock Empty Table"
,
NULL
,
NULL
,
true
);
static
MYSQL_THDVAR_BOOL
(
log_client_errors
,
0
,
"Tokudb Log Client Errors"
,
NULL
,
NULL
,
false
);
static
MYSQL_THDVAR_UINT
(
block_size
,
0
,
"fractal tree block size"
,
NULL
,
NULL
,
4
<<
20
,
// default
4096
,
// min
~
0U
,
// max
1
// blocksize???
);
static
MYSQL_THDVAR_UINT
(
read_block_size
,
0
,
"fractal tree read block size"
,
NULL
,
NULL
,
128
*
1024
,
// default
4096
,
// min
~
0U
,
// max
1
// blocksize???
);
static
MYSQL_THDVAR_UINT
(
read_buf_size
,
0
,
"fractal tree read block size"
,
//TODO: Is this a typo?
NULL
,
NULL
,
128
*
1024
,
// default
0
,
// min
1
*
1024
*
1024
,
// max
1
// blocksize???
);
#if TOKU_INCLUDE_UPSERT
static
MYSQL_THDVAR_BOOL
(
disable_slow_update
,
PLUGIN_VAR_THDLOCAL
,
"disable slow update"
,
NULL
,
// check
NULL
,
// update
false
// default
);
static
MYSQL_THDVAR_BOOL
(
disable_slow_upsert
,
PLUGIN_VAR_THDLOCAL
,
"disable slow upsert"
,
NULL
,
// check
NULL
,
// update
false
// default
);
#endif
static
MYSQL_THDVAR_UINT
(
analyze_time
,
0
,
"analyze time"
,
NULL
,
NULL
,
60
,
// default
0
,
// min
~
0U
,
// max
1
// blocksize???
);
static
void
tokudb_checkpoint_lock
(
THD
*
thd
);
static
void
tokudb_checkpoint_unlock
(
THD
*
thd
);
static
void
tokudb_checkpoint_lock_update
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
var_ptr
,
const
void
*
save
)
{
my_bool
*
val
=
(
my_bool
*
)
var_ptr
;
*
val
=
*
(
my_bool
*
)
save
?
true
:
false
;
if
(
*
val
)
{
tokudb_checkpoint_lock
(
thd
);
}
else
{
tokudb_checkpoint_unlock
(
thd
);
}
}
static
MYSQL_THDVAR_BOOL
(
checkpoint_lock
,
0
,
"Tokudb Checkpoint Lock"
,
NULL
,
tokudb_checkpoint_lock_update
,
false
);
static
const
char
*
tokudb_row_format_names
[]
=
{
"tokudb_uncompressed"
,
"tokudb_zlib"
,
"tokudb_quicklz"
,
"tokudb_lzma"
,
"tokudb_fast"
,
"tokudb_small"
,
"tokudb_default"
,
NullS
};
static
TYPELIB
tokudb_row_format_typelib
=
{
array_elements
(
tokudb_row_format_names
)
-
1
,
"tokudb_row_format_typelib"
,
tokudb_row_format_names
,
NULL
};
static
MYSQL_THDVAR_ENUM
(
row_format
,
PLUGIN_VAR_OPCMDARG
,
"Specifies the compression method for a table during this session. "
"Possible values are TOKUDB_UNCOMPRESSED, TOKUDB_ZLIB, TOKUDB_QUICKLZ, "
"TOKUDB_LZMA, TOKUDB_FAST, TOKUDB_SMALL and TOKUDB_DEFAULT"
,
NULL
,
NULL
,
SRV_ROW_FORMAT_DEFAULT
,
&
tokudb_row_format_typelib
);
srv_row_format_t
get_row_format
(
THD
*
thd
)
{
return
(
srv_row_format_t
)
THDVAR
(
thd
,
row_format
);
}
static
MYSQL_THDVAR_UINT
(
lock_timeout_debug
,
0
,
"TokuDB lock timeout debug"
,
NULL
,
NULL
,
0
,
0
,
~
0U
,
1
);
static
MYSQL_THDVAR_STR
(
last_lock_timeout
,
PLUGIN_VAR_MEMALLOC
,
"last TokuDB lock timeout"
,
NULL
,
NULL
,
NULL
);
static
void
tokudb_print_error
(
const
DB_ENV
*
db_env
,
const
char
*
db_errpfx
,
const
char
*
buffer
);
static
void
tokudb_cleanup_log_files
(
void
);
...
...
@@ -804,62 +622,6 @@ exit:
TOKUDB_DBUG_RETURN
(
result
);
}
uint
get_pk_insert_mode
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
pk_insert_mode
);
}
bool
get_load_save_space
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
load_save_space
)
!=
0
);
}
bool
get_disable_slow_alter
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_alter
)
!=
0
);
}
bool
get_disable_hot_alter
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
disable_hot_alter
)
!=
0
;
}
bool
get_create_index_online
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
create_index_online
)
!=
0
);
}
bool
get_disable_prefetching
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_prefetching
)
!=
0
);
}
bool
get_prelock_empty
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
prelock_empty
)
!=
0
);
}
bool
get_log_client_errors
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
log_client_errors
)
!=
0
);
}
uint
get_tokudb_block_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
block_size
);
}
uint
get_tokudb_read_block_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
read_block_size
);
}
uint
get_tokudb_read_buf_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
read_buf_size
);
}
#if TOKU_INCLUDE_UPSERT
bool
get_disable_slow_update
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_update
)
!=
0
);
}
bool
get_disable_slow_upsert
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_upsert
)
!=
0
);
}
#endif
uint
get_analyze_time
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
analyze_time
);
}
typedef
struct
txn_progress_info
{
char
status
[
200
];
...
...
@@ -1505,7 +1267,6 @@ static struct st_mysql_sys_var *tokudb_system_variables[] = {
MYSQL_SYSVAR
(
init_flags
),
MYSQL_SYSVAR
(
checkpointing_period
),
MYSQL_SYSVAR
(
prelock_empty
),
MYSQL_SYSVAR
(
log_client_errors
),
MYSQL_SYSVAR
(
checkpoint_lock
),
MYSQL_SYSVAR
(
write_status_frequency
),
MYSQL_SYSVAR
(
read_status_frequency
),
...
...
storage/tokudb/hatoku_hton.h
View file @
9f5293de
...
...
@@ -109,25 +109,250 @@ enum srv_row_format_enum {
typedef
enum
srv_row_format_enum
srv_row_format_t
;
// thread variables
uint
get_pk_insert_mode
(
THD
*
thd
);
bool
get_load_save_space
(
THD
*
thd
);
bool
get_disable_slow_alter
(
THD
*
thd
);
bool
get_disable_hot_alter
(
THD
*
thd
);
bool
get_create_index_online
(
THD
*
thd
);
bool
get_disable_prefetching
(
THD
*
thd
);
bool
get_prelock_empty
(
THD
*
thd
);
bool
get_log_client_errors
(
THD
*
thd
);
uint
get_tokudb_block_size
(
THD
*
thd
);
uint
get_tokudb_read_block_size
(
THD
*
thd
);
uint
get_tokudb_read_buf_size
(
THD
*
thd
);
srv_row_format_t
get_row_format
(
THD
*
thd
);
static
MYSQL_THDVAR_BOOL
(
commit_sync
,
PLUGIN_VAR_THDLOCAL
,
"sync on txn commit"
,
/* check */
NULL
,
/* update */
NULL
,
/* default*/
true
);
static
MYSQL_THDVAR_UINT
(
pk_insert_mode
,
0
,
"set the primary key insert mode"
,
NULL
,
NULL
,
1
,
// default
0
,
// min?
2
,
// max
1
// blocksize
);
static
uint
get_pk_insert_mode
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
pk_insert_mode
);
}
static
MYSQL_THDVAR_BOOL
(
load_save_space
,
0
,
"if on, intial loads are slower but take less space"
,
NULL
,
NULL
,
false
);
static
bool
get_load_save_space
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
load_save_space
)
!=
0
);
}
static
MYSQL_THDVAR_BOOL
(
disable_slow_alter
,
0
,
"if on, alter tables that require copy are disabled"
,
NULL
,
NULL
,
false
);
static
bool
get_disable_slow_alter
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_alter
)
!=
0
);
}
static
MYSQL_THDVAR_BOOL
(
disable_hot_alter
,
0
,
"if on, hot alter table is disabled"
,
NULL
,
NULL
,
false
);
static
bool
get_disable_hot_alter
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
disable_hot_alter
)
!=
0
;
}
static
MYSQL_THDVAR_BOOL
(
create_index_online
,
0
,
"if on, create index done online"
,
NULL
,
NULL
,
true
);
static
bool
get_create_index_online
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
create_index_online
)
!=
0
);
}
static
MYSQL_THDVAR_BOOL
(
disable_prefetching
,
0
,
"if on, prefetching disabled"
,
NULL
,
NULL
,
false
);
static
bool
get_disable_prefetching
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_prefetching
)
!=
0
);
}
static
MYSQL_THDVAR_BOOL
(
prelock_empty
,
0
,
"Tokudb Prelock Empty Table"
,
NULL
,
NULL
,
true
);
static
bool
get_prelock_empty
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
prelock_empty
)
!=
0
);
}
static
MYSQL_THDVAR_UINT
(
block_size
,
0
,
"fractal tree block size"
,
NULL
,
NULL
,
4
<<
20
,
// default
4096
,
// min
~
0U
,
// max
1
// blocksize???
);
static
uint
get_tokudb_block_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
block_size
);
}
static
MYSQL_THDVAR_UINT
(
read_block_size
,
0
,
"fractal tree read block size"
,
NULL
,
NULL
,
128
*
1024
,
// default
4096
,
// min
~
0U
,
// max
1
// blocksize???
);
static
uint
get_tokudb_read_block_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
read_block_size
);
}
static
MYSQL_THDVAR_UINT
(
read_buf_size
,
0
,
"fractal tree read block size"
,
//TODO: Is this a typo?
NULL
,
NULL
,
128
*
1024
,
// default
0
,
// min
1
*
1024
*
1024
,
// max
1
// blocksize???
);
static
uint
get_tokudb_read_buf_size
(
THD
*
thd
)
{
return
THDVAR
(
thd
,
read_buf_size
);
}
#if TOKU_INCLUDE_UPSERT
bool
get_enable_fast_update
(
THD
*
thd
);
bool
get_disable_slow_update
(
THD
*
thd
);
bool
get_enable_fast_upsert
(
THD
*
thd
);
bool
get_disable_slow_upsert
(
THD
*
thd
);
static
MYSQL_THDVAR_BOOL
(
disable_slow_update
,
PLUGIN_VAR_THDLOCAL
,
"disable slow update"
,
NULL
,
// check
NULL
,
// update
false
// default
);
static
bool
get_disable_slow_update
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_update
)
!=
0
);
}
static
MYSQL_THDVAR_BOOL
(
disable_slow_upsert
,
PLUGIN_VAR_THDLOCAL
,
"disable slow upsert"
,
NULL
,
// check
NULL
,
// update
false
// default
);
static
bool
get_disable_slow_upsert
(
THD
*
thd
)
{
return
(
THDVAR
(
thd
,
disable_slow_upsert
)
!=
0
);
}
#endif
uint
get_analyze_time
(
THD
*
thd
);
static
MYSQL_THDVAR_UINT
(
analyze_time
,
0
,
"analyze time"
,
NULL
,
NULL
,
60
,
// default
0
,
// min
~
0U
,
// max
1
// blocksize???
);
static
void
tokudb_checkpoint_lock
(
THD
*
thd
);
static
void
tokudb_checkpoint_unlock
(
THD
*
thd
);
static
void
tokudb_checkpoint_lock_update
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
var_ptr
,
const
void
*
save
)
{
my_bool
*
val
=
(
my_bool
*
)
var_ptr
;
*
val
=
*
(
my_bool
*
)
save
?
true
:
false
;
if
(
*
val
)
{
tokudb_checkpoint_lock
(
thd
);
}
else
{
tokudb_checkpoint_unlock
(
thd
);
}
}
static
MYSQL_THDVAR_BOOL
(
checkpoint_lock
,
0
,
"Tokudb Checkpoint Lock"
,
NULL
,
tokudb_checkpoint_lock_update
,
false
);
static
const
char
*
tokudb_row_format_names
[]
=
{
"tokudb_uncompressed"
,
"tokudb_zlib"
,
"tokudb_quicklz"
,
"tokudb_lzma"
,
"tokudb_fast"
,
"tokudb_small"
,
"tokudb_default"
,
NullS
};
static
TYPELIB
tokudb_row_format_typelib
=
{
array_elements
(
tokudb_row_format_names
)
-
1
,
"tokudb_row_format_typelib"
,
tokudb_row_format_names
,
NULL
};
static
MYSQL_THDVAR_ENUM
(
row_format
,
PLUGIN_VAR_OPCMDARG
,
"Specifies the compression method for a table during this session. "
"Possible values are TOKUDB_UNCOMPRESSED, TOKUDB_ZLIB, TOKUDB_QUICKLZ, "
"TOKUDB_LZMA, TOKUDB_FAST, TOKUDB_SMALL and TOKUDB_DEFAULT"
,
NULL
,
NULL
,
SRV_ROW_FORMAT_DEFAULT
,
&
tokudb_row_format_typelib
);
static
srv_row_format_t
get_row_format
(
THD
*
thd
)
{
return
(
srv_row_format_t
)
THDVAR
(
thd
,
row_format
);
}
static
MYSQL_THDVAR_UINT
(
lock_timeout_debug
,
0
,
"TokuDB lock timeout debug"
,
NULL
,
NULL
,
0
,
0
,
~
0U
,
1
);
static
MYSQL_THDVAR_STR
(
last_lock_timeout
,
PLUGIN_VAR_MEMALLOC
,
"last TokuDB lock timeout"
,
NULL
,
NULL
,
NULL
);
extern
HASH
tokudb_open_tables
;
extern
pthread_mutex_t
tokudb_mutex
;
...
...
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