Mysql主要参数
在优化MySQL时,有两个配置参数是最重要的,即table_cache和key_buffer_size。而具体到应用环境还有个查询参数query_cache_size直接影响查询性能。下面主要是整理的关于下面三个参数的文章
1.table_cache 表缓存
2.key_buffer_size 键缓冲
3.query_cache_size查询缓存
4.其他参数
5.参考文章
首先,在了解这些参数设置前需要明确的概念是
什么是<a href="http://www.580top.com/html/%3Ca%20href=" http:="" www.580top.com="" html="" mysql="" l_13_1.htm"="" title="mysql" style="margin: 0px; padding: 0px; color: rgb(58, 150, 104); text-decoration: none;">mysql/l_13_1.htm" title="MYSQL" >MYSQL的缓存:在内存中预留的块
访问内存中的数据快于访问磁盘上的数据。
把数据保存在内存中更重要的是可以减少磁盘IO操作。
当数据变化(update insert delete...)时对应的缓存就失效
内存是有限的
3、query_cache_size查询缓存
MySQL服务器可以使用查询缓存来提高那些重复执行的SELECT语句的处理速度。它对性能的提高通常都是惊人的。查询缓存的工作方式如下所示:
第一次执行某条SELECT语句的时候,服务器记住该查询的文本内容和它返回的结果。
服务器下一次碰到这个语句的时候,它不会再次执行该语句。作为代替,它直接从查询缓存中的得到结果并把结果返回给客户端。
查询缓存是基于服务器所接收到的查询字符串的文本内容的。如果某些查询的文本完全相同,那些它就认为这些查询是相同的。如果某些查询的字符不同,或者来自那些使用了不同的字符集或通讯协议的客户端,那么它会认为这些查询是不同的。同样,如果某些查询采用其它的功能相当、但是实际上没有指向相同的数据表(例如引用了不同的数据库中的同名数据表),那么它们也是不同的。
当数据表被更新了之后,涉及到该数据表的任何缓存查询都变成无效的,并且会被丢弃。这可以防止服务器返回过期的结果。
在默认情况下,MySQL对查询缓存的支持是内建的。如果你不希望使用这种缓存,并且想避免它所导致的性能开销,可以使用--without-query-cache选项来运行配置脚本建立服务器。
如果需要检测某个服务器是否支持查询缓存,可以检查它的have_query_cache系统变量:
mysql> SHOW VARIABLES LIKE ’have_query_cache’;
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| have_query_cache | YES |
+------------------+-------+