免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2378 | 回复: 0

MYSQL优化 [复制链接]

论坛徽章:
0
发表于 2009-12-27 16:34 |显示全部楼层

1.用show status命令查看SQL的执行频率
show status like 'Com_%';
2.通过慢查询日志定位执行效率低的SQL语句
如何打开慢查询日志呢,只需要在mysql的配置文件下面加上如下代码
windows系统是my.ini:

log-slow-queries=D:/Program Files/wamp/MySQL Server 5.2/data/slowquery.log
long_query_time=2

linux系统是my.cnf:

log-slow-queries=/var/local/mysql/slowquery.log
long_query_time=2
注:
log-slow-queries 设置把日志写在那里,为空的时候,系统会给慢查询日志赋予主机名,并被附加slow.log. /var/local/mysql/slowquery.log为日志存放的文件的位置,一般这个目录要有mysql的运行帐号的可写权限,一般都将这个目录设置为mysql的数据存放目录

long_query_time=2中的2表示查询超过两秒才记录.

3.mysql性能参数 (key_buffer_size与table cache)
key_buffer_size:设置索引块缓存的大小,可以将表的索引放到指定的索引缓存中,例如:
先建一个索引:set global xy_cache2.key_buffer_size=250*1024;
global对每个新连接都生效,cache为新的key_buffer名称
然后把表的索引放到指定的索引缓存中:
cache index first,second in xy_cache2;
由于cache index命令在每次服务器重起时key_buffer中的数据将清空。如想每次重新启动都能将相应表自动防到key_buffer中,可以在配置文件中设置init-file选项来指定包含cache index语句的文件路径然后再写入cache index语句,如:
vi /etc/my.cnf

key_buffer_size = 3G
xy_cache_key_buffer_size = 2G
init_file=/path/to/data-directory/mysqld_init.sql

之后再写入:
cache index a.t1, a.t2, b.t3 in xy_cache;


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u3/106588/showart_2132125.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP