首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | linux相关 | linux认证 | 下载中心 | 专题
oklinux
 系统管理:中文环境 系统管理 桌面应用 内核技术 Linux基础:安装配置 常用命令 经验技巧 软件应用 Linux数据库:Mysql POSTGRE
 网络管理:网络安全 网络应用 Linux服务器 编程开发:PHP CC++ Python Perl SHELL 嵌入式开发 | PHP基础 PHP技巧 PHP应用 PHP文摘
 首页 linux资讯动态 Linux专题 | 其他Unix Linux解决方案 硬件相关 Linux认证 企业应用 Apache | 相关下载:资料 参考手册 服务器
 → 当前位置:首页>linux数据库>mysql>正文

Linux系统高负载 MySQL数据库彻底优化

OKLinux www.oklinux.cn 2007-06-25 来源: skid 会员收藏 游客收藏

同时在线访问量继续增大对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机或者时不时的服务器卡一下这个问题曾经困扰了我半个多月MySQL使用是很具伸缩性的算法,因此你通常能用很少的内存运行或给MySQL更多的被存以得到更好的性能。

 

安装好mysql后,配制文件应该在/usr/local/mysql/share/mysql目录中,配制文件有几个,有my-huge.cnf my-medium.cnf my-large.cnf my-small.cnf,不同的流量的网站和不同配制的服务器环境,当然需要有不同的配制文件了。

 

一般的情况下,my-medium.cnf这个配制文件就能满足我们的大多需要;一般我们会把配置文件拷贝到/etc/my.cnf 只需要修改这个配置文件就可以了,使用mysqladmin variables extended-status -uroot -p可以看到目前的参数,有3个配置参数是最重要的,即key_buffer_size,query_cache_size,table_cache。

 

key_buffer_size只对MyISAM表起作用,key_buffer_size指定索引缓冲区的大小,它决定索引处理的速度,尤其是索引读的速度。一般我们设为16M,实际上稍微大一点的站点 这个数字是远远不够的,通过检查状态值Key_read_requests和Key_reads,可以知道key_buffer_size设置是否合理。比例key_reads / key_read_requests应该尽可能的低,至少是1:100,1:1000更好(上述状态值可以使用SHOW STATUS LIKE ‘key_read%’获得)。 或者如果你装了phpmyadmin 可以通过服务器运行状态看到,笔者推荐用phpmyadmin管理mysql,以下的状态值都是本人通过phpmyadmin获得的实例分析:

 

这个服务器已经运行了20天

key_buffer_size – 128M

key_read_requests – 650759289

key_reads - 79112

比例接近1:8000 健康状况非常好

 

另外一个估计key_buffer_size的办法 把你网站数据库的每个表的索引所占空间大小加起来看看以此服务器为例:比较大的几个表索引加起来大概125M 这个数字会随着表变大而变大。

 

从4.0.1开始,MySQL提供了查询缓冲机制。使用查询缓冲,MySQL将SELECT语句和查询结果存放在缓冲区中,今后对于同样的SELECT语句(区分大小写),将直接从缓冲区中读取结果。根据MySQL用户手册,使用查询缓冲最多可以达到238%的效率。

 

通过调节以下几个参数可以知道query_cache_size设置得是否合理

Qcache inserts

Qcache hits

Qcache lowmem prunes

Qcache free blocks

Qcache total blocks

 

Qcache_lowmem_prunes的值非常大,则表明经常出现缓冲不够的情况,同时Qcache_hits的值非常大,则表明查询缓冲使用非常频繁,此时需要增加缓冲大小Qcache_hits的值不大,则表明你的查询重复率很低,这种情况下使用查询缓冲反而会影响效率,那么可以考虑不用查询缓冲。此外,在SELECT语句中加入SQL_NO_CACHE可以明确表示不使用查询缓冲。

Qcache_free_blocks,如果该值非常大,则表明缓冲区中碎片很多query_cache_type指定是否使用查询缓冲

 

我设置:

 

QUOTE:

query_cache_size = 32M

共4页: 上一页 1 [2] [3] [4] 下一页
上一篇:Ubuntu Linux操作系统中自带的程序介绍   下一篇:Linux Troubleshooting Bible(英文教程)

收藏于收藏夹】 【评论】 【推荐】 【投稿】 【打印】 【关闭

相关文章
·MySQL5.0新特性教程存储过程:第四讲
·MySQL5.0新特性教程存储过程:第一讲
·一个PHPer的面试经历
·架设freeradius+mysql的radius服务器
·MySQL中文参考手册--获得数据库和表的信息
·MySQL中文参考手册--创造并使用一个数据库
·忘了MySQL的管理员密码怎么办?
·MySQL提供与Linux绑定的数据库下载
·小技巧:怎样在Mysql中直接储存图片
·让PHP网站运转如飞MySQL的优化
发表评论
密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。)
站内搜索
阅读排行榜
·Linux 安装 Mysql
·如何在Linux系统中安装MyS
·在Linux 环境下安装 Mysql
·在Linux上安装MySQL Serve
·图形化管理MySQL更轻松
·[Mysql]IIS+mysql+php相关
·MySQL创始人David Axmark
·Heartbeat_2.0.3配置MySQL
·[MySQL]入门学习从安装入
·新手上路:MySQL初学者之
最新文章
·Linux系统上安装MYSQL数据
·Linux下MySQL数据库二进制
·利用Crontab为Linux定时备
·Ubuntu操作系统下安装MySQ
·Linux下建立Mysql镜像数据
·MySQL管理
·MYSQL视频教程(网络数据库
·MySQL用户管理
·MYSQL视频教程(网络数据库
·MYSQL视频教程(网络数据库
·Mysql常识与基本操作
·Linux数据库大比拚
·MYSQL初学者使用指南
·MySQL TEXT、DATE、SET 数
·Mysql高效的模糊查询

设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2007 All rights reserved OKLinux.Cn 版权所有