Chinaunix首页 | 论坛 | 博客
  • 博客访问: 160795
  • 博文数量: 52
  • 博客积分: 2295
  • 博客等级: 大尉
  • 技术积分: 540
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-22 17:42
文章分类

全部博文(52)

文章存档

2013年(1)

2012年(11)

2011年(1)

2010年(31)

2009年(8)

我的朋友

分类: Mysql/postgreSQL

2009-12-27 16:34:20

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;
阅读(1044) | 评论(0) | 转发(0) |
0

上一篇:linux文件系统

下一篇:MYSQL安装错误的解决

给主人留下些什么吧!~~