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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
1bff548c
Commit
1bff548c
authored
Sep 06, 2005
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
Merge sanja.is.com.ua:/home/bell/mysql/bk/work-4.0
into sanja.is.com.ua:/home/bell/mysql/bk/work-4.1
parents
6a5f0070
5a97e646
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
85 additions
and
36 deletions
+85
-36
sql/mysql_priv.h
sql/mysql_priv.h
+2
-0
sql/sql_cache.cc
sql/sql_cache.cc
+80
-34
sql/sql_cache.h
sql/sql_cache.h
+3
-2
No files found.
sql/mysql_priv.h
View file @
1bff548c
...
@@ -412,6 +412,7 @@ struct Query_cache_query_flags
...
@@ -412,6 +412,7 @@ struct Query_cache_query_flags
#define query_cache_store_query(A, B) query_cache.store_query(A, B)
#define query_cache_store_query(A, B) query_cache.store_query(A, B)
#define query_cache_destroy() query_cache.destroy()
#define query_cache_destroy() query_cache.destroy()
#define query_cache_result_size_limit(A) query_cache.result_size_limit(A)
#define query_cache_result_size_limit(A) query_cache.result_size_limit(A)
#define query_cache_init() query_cache.init()
#define query_cache_resize(A) query_cache.resize(A)
#define query_cache_resize(A) query_cache.resize(A)
#define query_cache_set_min_res_unit(A) query_cache.set_min_res_unit(A)
#define query_cache_set_min_res_unit(A) query_cache.set_min_res_unit(A)
#define query_cache_invalidate3(A, B, C) query_cache.invalidate(A, B, C)
#define query_cache_invalidate3(A, B, C) query_cache.invalidate(A, B, C)
...
@@ -425,6 +426,7 @@ struct Query_cache_query_flags
...
@@ -425,6 +426,7 @@ struct Query_cache_query_flags
#define query_cache_store_query(A, B)
#define query_cache_store_query(A, B)
#define query_cache_destroy()
#define query_cache_destroy()
#define query_cache_result_size_limit(A)
#define query_cache_result_size_limit(A)
#define query_cache_init()
#define query_cache_resize(A)
#define query_cache_resize(A)
#define query_cache_set_min_res_unit(A)
#define query_cache_set_min_res_unit(A)
#define query_cache_invalidate3(A, B, C)
#define query_cache_invalidate3(A, B, C)
...
...
sql/sql_cache.cc
View file @
1bff548c
...
@@ -574,13 +574,18 @@ void query_cache_insert(NET *net, const char *packet, ulong length)
...
@@ -574,13 +574,18 @@ void query_cache_insert(NET *net, const char *packet, ulong length)
{
{
DBUG_ENTER
(
"query_cache_insert"
);
DBUG_ENTER
(
"query_cache_insert"
);
#ifndef DBUG_OFF
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
// Check if we have called query_cache.wreck() (which disables the cache)
/*
if
(
query_cache
.
query_cache_size
==
0
)
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after guard
mutex lock
*/
if
(
unlikely
(
query_cache
.
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
query_cache
.
structure_guard_mutex
);
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
#endif
}
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
net
->
query_cache_query
);
net
->
query_cache_query
);
if
(
query_block
)
if
(
query_block
)
...
@@ -623,14 +628,20 @@ void query_cache_abort(NET *net)
...
@@ -623,14 +628,20 @@ void query_cache_abort(NET *net)
{
{
DBUG_ENTER
(
"query_cache_abort"
);
DBUG_ENTER
(
"query_cache_abort"
);
#ifndef DBUG_OFF
// Check if we have called query_cache.wreck() (which disables the cache)
if
(
query_cache
.
query_cache_size
==
0
)
DBUG_VOID_RETURN
;
#endif
if
(
net
->
query_cache_query
!=
0
)
// Quick check on unlocked structure
if
(
net
->
query_cache_query
!=
0
)
// Quick check on unlocked structure
{
{
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
/*
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after guard
mutex lock
*/
if
(
unlikely
(
query_cache
.
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
query_cache
.
structure_guard_mutex
);
DBUG_VOID_RETURN
;
}
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
net
->
query_cache_query
);
net
->
query_cache_query
);
if
(
query_block
)
// Test if changed by other thread
if
(
query_block
)
// Test if changed by other thread
...
@@ -652,11 +663,6 @@ void query_cache_end_of_result(THD *thd)
...
@@ -652,11 +663,6 @@ void query_cache_end_of_result(THD *thd)
{
{
DBUG_ENTER
(
"query_cache_end_of_result"
);
DBUG_ENTER
(
"query_cache_end_of_result"
);
#ifndef DBUG_OFF
// Check if we have called query_cache.wreck() (which disables the cache)
if
(
query_cache
.
query_cache_size
==
0
)
DBUG_VOID_RETURN
;
#endif
if
(
thd
->
net
.
query_cache_query
!=
0
)
// Quick check on unlocked structure
if
(
thd
->
net
.
query_cache_query
!=
0
)
// Quick check on unlocked structure
{
{
#ifdef EMBEDDED_LIBRARY
#ifdef EMBEDDED_LIBRARY
...
@@ -664,6 +670,17 @@ void query_cache_end_of_result(THD *thd)
...
@@ -664,6 +670,17 @@ void query_cache_end_of_result(THD *thd)
emb_count_querycache_size
(
thd
));
emb_count_querycache_size
(
thd
));
#endif
#endif
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
STRUCT_LOCK
(
&
query_cache
.
structure_guard_mutex
);
/*
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after guard
mutex lock
*/
if
(
unlikely
(
query_cache
.
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
query_cache
.
structure_guard_mutex
);
DBUG_VOID_RETURN
;
}
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
Query_cache_block
*
query_block
=
((
Query_cache_block
*
)
thd
->
net
.
query_cache_query
);
thd
->
net
.
query_cache_query
);
if
(
query_block
)
if
(
query_block
)
...
@@ -743,9 +760,14 @@ ulong Query_cache::resize(ulong query_cache_size_arg)
...
@@ -743,9 +760,14 @@ ulong Query_cache::resize(ulong query_cache_size_arg)
DBUG_ENTER
(
"Query_cache::resize"
);
DBUG_ENTER
(
"Query_cache::resize"
);
DBUG_PRINT
(
"qcache"
,
(
"from %lu to %lu"
,
query_cache_size
,
DBUG_PRINT
(
"qcache"
,
(
"from %lu to %lu"
,
query_cache_size
,
query_cache_size_arg
));
query_cache_size_arg
));
free_cache
(
0
);
DBUG_ASSERT
(
initialized
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
if
(
query_cache_size
>
0
)
free_cache
();
query_cache_size
=
query_cache_size_arg
;
query_cache_size
=
query_cache_size_arg
;
DBUG_RETURN
(
::
query_cache_size
=
init_cache
());
::
query_cache_size
=
init_cache
();
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
DBUG_RETURN
(
::
query_cache_size
);
}
}
...
@@ -1388,7 +1410,7 @@ void Query_cache::destroy()
...
@@ -1388,7 +1410,7 @@ void Query_cache::destroy()
}
}
else
else
{
{
free_cache
(
1
);
free_cache
();
pthread_mutex_destroy
(
&
structure_guard_mutex
);
pthread_mutex_destroy
(
&
structure_guard_mutex
);
initialized
=
0
;
initialized
=
0
;
}
}
...
@@ -1417,8 +1439,6 @@ ulong Query_cache::init_cache()
...
@@ -1417,8 +1439,6 @@ ulong Query_cache::init_cache()
int
align
;
int
align
;
DBUG_ENTER
(
"Query_cache::init_cache"
);
DBUG_ENTER
(
"Query_cache::init_cache"
);
if
(
!
initialized
)
init
();
approx_additional_data_size
=
(
sizeof
(
Query_cache
)
+
approx_additional_data_size
=
(
sizeof
(
Query_cache
)
+
sizeof
(
gptr
)
*
(
def_query_hash_size
+
sizeof
(
gptr
)
*
(
def_query_hash_size
+
def_table_hash_size
));
def_table_hash_size
));
...
@@ -1476,14 +1496,9 @@ ulong Query_cache::init_cache()
...
@@ -1476,14 +1496,9 @@ ulong Query_cache::init_cache()
goto
err
;
goto
err
;
query_cache_size
-=
additional_data_size
;
query_cache_size
-=
additional_data_size
;
STRUCT_LOCK
(
&
structure_guard_mutex
);
if
(
!
(
cache
=
(
byte
*
)
my_malloc_lock
(
query_cache_size
+
additional_data_size
,
MYF
(
0
))))
if
(
!
(
cache
=
(
byte
*
)
my_malloc_lock
(
query_cache_size
+
additional_data_size
,
MYF
(
0
))))
{
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
goto
err
;
goto
err
;
}
DBUG_PRINT
(
"qcache"
,
(
"cache length %lu, min unit %lu, %u bins"
,
DBUG_PRINT
(
"qcache"
,
(
"cache length %lu, min unit %lu, %u bins"
,
query_cache_size
,
min_allocation_unit
,
mem_bin_num
));
query_cache_size
,
min_allocation_unit
,
mem_bin_num
));
...
@@ -1579,7 +1594,6 @@ ulong Query_cache::init_cache()
...
@@ -1579,7 +1594,6 @@ ulong Query_cache::init_cache()
queries_in_cache
=
0
;
queries_in_cache
=
0
;
queries_blocks
=
0
;
queries_blocks
=
0
;
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
DBUG_RETURN
(
query_cache_size
+
DBUG_RETURN
(
query_cache_size
+
additional_data_size
+
approx_additional_data_size
);
additional_data_size
+
approx_additional_data_size
);
...
@@ -1595,6 +1609,7 @@ void Query_cache::make_disabled()
...
@@ -1595,6 +1609,7 @@ void Query_cache::make_disabled()
{
{
DBUG_ENTER
(
"Query_cache::make_disabled"
);
DBUG_ENTER
(
"Query_cache::make_disabled"
);
query_cache_size
=
0
;
query_cache_size
=
0
;
queries_blocks
=
0
;
free_memory
=
0
;
free_memory
=
0
;
bins
=
0
;
bins
=
0
;
steps
=
0
;
steps
=
0
;
...
@@ -1606,14 +1621,11 @@ void Query_cache::make_disabled()
...
@@ -1606,14 +1621,11 @@ void Query_cache::make_disabled()
}
}
void
Query_cache
::
free_cache
(
my_bool
destruction
)
void
Query_cache
::
free_cache
()
{
{
DBUG_ENTER
(
"Query_cache::free_cache"
);
DBUG_ENTER
(
"Query_cache::free_cache"
);
if
(
query_cache_size
>
0
)
if
(
query_cache_size
>
0
)
{
{
if
(
!
destruction
)
STRUCT_LOCK
(
&
structure_guard_mutex
);
flush_cache
();
flush_cache
();
#ifndef DBUG_OFF
#ifndef DBUG_OFF
if
(
bins
[
0
].
free_blocks
==
0
)
if
(
bins
[
0
].
free_blocks
==
0
)
...
@@ -1635,8 +1647,6 @@ void Query_cache::free_cache(my_bool destruction)
...
@@ -1635,8 +1647,6 @@ void Query_cache::free_cache(my_bool destruction)
make_disabled
();
make_disabled
();
hash_free
(
&
queries
);
hash_free
(
&
queries
);
hash_free
(
&
tables
);
hash_free
(
&
tables
);
if
(
!
destruction
)
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
}
}
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
...
@@ -2266,7 +2276,19 @@ Query_cache::allocate_block(ulong len, my_bool not_less, ulong min,
...
@@ -2266,7 +2276,19 @@ Query_cache::allocate_block(ulong len, my_bool not_less, ulong min,
}
}
if
(
!
under_guard
)
if
(
!
under_guard
)
{
STRUCT_LOCK
(
&
structure_guard_mutex
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
/*
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after
guard mutex lock
*/
if
(
unlikely
(
query_cache
.
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
DBUG_RETURN
(
0
);
}
}
/* Free old queries until we have enough memory to store this block */
/* Free old queries until we have enough memory to store this block */
Query_cache_block
*
block
;
Query_cache_block
*
block
;
...
@@ -2764,6 +2786,17 @@ void Query_cache::pack_cache()
...
@@ -2764,6 +2786,17 @@ void Query_cache::pack_cache()
{
{
DBUG_ENTER
(
"Query_cache::pack_cache"
);
DBUG_ENTER
(
"Query_cache::pack_cache"
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
/*
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after
guard mutex lock
*/
if
(
unlikely
(
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
structure_guard_mutex
);
DBUG_VOID_RETURN
;
}
DBUG_EXECUTE
(
"check_querycache"
,
query_cache
.
check_integrity
(
1
););
DBUG_EXECUTE
(
"check_querycache"
,
query_cache
.
check_integrity
(
1
););
byte
*
border
=
0
;
byte
*
border
=
0
;
...
@@ -3073,6 +3106,7 @@ my_bool Query_cache::join_results(ulong join_limit)
...
@@ -3073,6 +3106,7 @@ my_bool Query_cache::join_results(ulong join_limit)
STRUCT_LOCK
(
&
structure_guard_mutex
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
if
(
queries_blocks
!=
0
)
if
(
queries_blocks
!=
0
)
{
{
DBUG_ASSERT
(
query_cache_size
>
0
);
Query_cache_block
*
block
=
queries_blocks
;
Query_cache_block
*
block
=
queries_blocks
;
do
do
{
{
...
@@ -3369,7 +3403,19 @@ my_bool Query_cache::check_integrity(bool not_locked)
...
@@ -3369,7 +3403,19 @@ my_bool Query_cache::check_integrity(bool not_locked)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
if
(
!
not_locked
)
if
(
!
not_locked
)
{
STRUCT_LOCK
(
&
structure_guard_mutex
);
STRUCT_LOCK
(
&
structure_guard_mutex
);
/*
It is very unlikely that following condition is TRUE (it is possible
only if other thread is resizing cache), so we check it only after
guard mutex lock
*/
if
(
unlikely
(
query_cache_size
==
0
))
{
STRUCT_UNLOCK
(
&
query_cache
.
structure_guard_mutex
);
DBUG_RETURN
(
0
);
}
}
if
(
hash_check
(
&
queries
))
if
(
hash_check
(
&
queries
))
{
{
...
...
sql/sql_cache.h
View file @
1bff548c
...
@@ -312,10 +312,9 @@ class Query_cache
...
@@ -312,10 +312,9 @@ class Query_cache
Following function control structure_guard_mutex
Following function control structure_guard_mutex
by themself or don't need structure_guard_mutex
by themself or don't need structure_guard_mutex
*/
*/
void
init
();
ulong
init_cache
();
ulong
init_cache
();
void
make_disabled
();
void
make_disabled
();
void
free_cache
(
my_bool
destruction
);
void
free_cache
();
Query_cache_block
*
write_block_data
(
ulong
data_len
,
gptr
data
,
Query_cache_block
*
write_block_data
(
ulong
data_len
,
gptr
data
,
ulong
header_len
,
ulong
header_len
,
Query_cache_block
::
block_type
type
,
Query_cache_block
::
block_type
type
,
...
@@ -351,6 +350,8 @@ class Query_cache
...
@@ -351,6 +350,8 @@ class Query_cache
uint
def_query_hash_size
=
QUERY_CACHE_DEF_QUERY_HASH_SIZE
,
uint
def_query_hash_size
=
QUERY_CACHE_DEF_QUERY_HASH_SIZE
,
uint
def_table_hash_size
=
QUERY_CACHE_DEF_TABLE_HASH_SIZE
);
uint
def_table_hash_size
=
QUERY_CACHE_DEF_TABLE_HASH_SIZE
);
/* initialize cache (mutex) */
void
init
();
/* resize query cache (return real query size, 0 if disabled) */
/* resize query cache (return real query size, 0 if disabled) */
ulong
resize
(
ulong
query_cache_size
);
ulong
resize
(
ulong
query_cache_size
);
/* set limit on result size */
/* set limit on result size */
...
...
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