mysql缓存
可以通过如下命令查看现在缓存的情况
[java]view plain
mysql>showstatuslike'qcache%';
+-------------------------+----------+
|Variable_name|Value|
+-------------------------+----------+
|Qcache_free_blocks|1|
|Qcache_free_memory|10475424|
|Qcache_hits|1|
|Qcache_inserts|1|
|Qcache_lowmem_prunes|0|
|Qcache_not_cached|0|
|Qcache_queries_in_cache|1|
|Qcache_total_blocks|4|
+-------------------------+----------+
8rowsinset(0.00sec)
其中各个参数的意义如下:
Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。
Qcache_free_memory:缓存中的空闲内存。
Qcache_hits:每次查询在缓存中命中时就增大
Qcache_inserts:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。
Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个 数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的 free_blocks和free_memory可以告诉您属于哪种情况)
Qcache_not_cached:不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。
Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。
Qcache_total_blocks:缓存中块的数量。
② mysql 一级缓存和二级缓存的区别
一、Session缓存(又称作事务缓存):Hibernate内置的,不能卸除。
缓存范围:缓存只能被当前Session对象访问。缓存的生命周期依赖于Session的生命周期,当Session被关闭后,缓存也就结束生命周期。
Hibernate一些与一级缓存相关的操作(时间点):
数据放入缓存:
1. save()。当session对象调用save()方法保存一个对象后,该对象会被放入到session的缓存中。
2. get()和load()。当session对象调用get()或load()方法从数据库取出一个对象后,该对象也会被放入到session的缓存中。
3. 使用HQL和QBC等从数据库中查询数据。
二、SessionFactory缓存(又称作应用缓存):使用第三方插件,可插拔。
③ mysql查询时怎么不用缓存
设置好查询缓存的大小就行了。比如设置个20MB.
SET GLOBAL QUERY_CACHE_SIZE=20000000;
mysql会将查询SQL和结果集存到缓存中,等下次遇到相同的SQL语句时,结果集从缓存中读取。
不设置就不用缓存了
④ 如何增加mysql数据的最大缓存大小
my.ini文件中
[wampmysqld]
port =3306
socket =/tmp/mysql.sock
key_buffer_size=16M//改这里
max_allowed_packet=1M
sort_buffer_size=512K
net_buffer_length=8K
read_buffer_size=256K
read_rnd_buffer_size=512K
myisam_sort_buffer_size=8M
PS 如果是安装版的mysql 你需要改的MY.ini 可能是在
C:ProgramDataMySQLMySQLServer5.7
这个目录有可能是隐藏的目录,你可以设置文件夹属性,显示所有文件
⑤ MYSQL会把查询的结果缓存多久
设置好查询缓存的大小就行了。比如设置个20MB. SET GLOBAL QUERY_CACHE_SIZE=20000000; mysql会将查询SQL和结果集存到缓存中,等下次遇到相同的SQL语句时,结果集从缓存中读龋 不设置就不用缓存了
⑥ mysql缓存什么情况下会释放
在多次查询查询时做数据缓存,memcache
-------------------------------------
答题不易,敬请采纳,以显鼓励!