首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux数据库>mysql>正文

个人经验总结:MySQL数据库优化技巧集锦

http://www.oklinux.cn  2008-07-09  赛迪网 Truman  会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn

一、我们可以且应该优化什么?

硬件

操作系统/软件库

SQL服务器(设置和查询)

应用编程接口(API)

应用程序

二、优化硬件

如果你需要庞大的数据库表(>2G),你应该考虑使用64位的硬件结构,像Alpha、Sparc或即将推出的IA64。因为MySQL内部使用大量64位的整数,64位的CPU将提供更好的性能。

对大数据库,优化的次序一般是RAM、快速硬盘、CPU能力。

更多的内存通过将最常用的键码页面存放在内存中可以加速键码的更新。

如果不使用事务安全(transaction-safe)的表或有大表并且想避免长文件检查,一台UPS就能够在电源故障时让系统安全关闭。

对于数据库存放在一个专用服务器的系统,应该考虑1G的以太网。延迟与吞吐量同样重要。

三、优化磁盘

为系统、程序和临时文件配备一个专用磁盘,如果确是进行很多修改工作,将更新日志和事务日志放在专用磁盘上。

低寻道时间对数据库磁盘非常重要。对与大表,你可以估计你将需要log(行数)/log(索引块长度/3*2/(键码长度 数据指针长度)) 1次寻到才能找到一行。对于有500000行的表,索引Mediun int类型的列,需要log(500000) / log(1024/3*2/(3 2)) 1=4次寻道。上述索引需要500000*7*3/2=5.2M的空间。实际上,大多数块将被缓存,所以大概只需要1-2次寻道。

然而对于写入(如上),你将需要4次寻道请求来找到在哪里存放新键码,而且一般要2次寻道来更新索引并写入一行。

对于非常大的数据库,你的应用将受到磁盘寻道速度的限制,随着数据量的增加呈N log N数据级递增。

将数据库和表分在不同的磁盘上。在MySQL中,你可以为此而使用符号链接。

条列磁盘(RAID 0)将提高读和写的吞吐量。

带镜像的条列(RAID 0 1)将更安全并提高读取的吞吐量。写入的吞吐量将有所降低。

不要对临时文件或可以很容易地重建的数据所在的磁盘使用镜像或RAID(除了RAID 0)。

在Linux上,在引导时对磁盘使用命令hdparm -m16 -d1以启用同时读写多个扇区和DMA功能。这可以将响应时间提高5~50%。

在Linux上,用async (默认)和noatime挂载磁盘(mount)。

对于某些特定应用,可以对某些特定表使用内存磁盘,但通常不需要。

四、优化操作系统

不要交换区。如果内存不足,增加更多的内存或配置你的系统使用较少内存。

不要使用NFS磁盘(会有NFS锁定的问题)。

增加系统和MySQL服务器的打开文件数量。(在safe_mysqld脚本中加入ulimit -n #)。

增加系统的进程和线程数量。

如果你有相对较少的大表,告诉文件系统不要将文件打碎在不同的磁道上(Solaris)。

使用支持大文件的文件系统(Solaris)。

选择使用哪种文件系统。在Linux上的Reiserfs对于打开、读写都非常快。文件检查只需几秒种。

五、选择应用编程接口

PERL

可在不同的操作系统和数据库之间移植。

适宜快速原型。

应该使用DBI/DBD接口。

PHP

比PERL易学。

使用比PERL少的资源。

通过升级到PHP4可以获得更快的速度。

C

MySQL的原生接口。

较快并赋予更多的控制。

低层,所以必须付出更多。

C

较高层次,给你更多的时间来编写应用。

仍在开发中

ODBC

运行在Windows和Unix上。

几乎可在不同的SQL服务器间移植。

较慢。MyODBC只是简单的直通驱动程序,比用原生接口慢19%。

有很多方法做同样的事。很难像很多ODBC驱动程序那样运行,在不同的领域还有不同的错误。

问题成堆。Microsoft偶尔还会改变接口。

不明朗的未来。(Microsoft更推崇OLE而非ODBC)

ODBC

运行在Windows和Unix上。

几乎可在不同的SQL服务器间移植。

较慢。MyODBC只是简单的直通驱动程序,比用原生接口慢19%。

有很多方法做同样的事。很难像很多ODBC驱动程序那样运行,在不同的领域还有不同的错误。

问题成堆。Microsoft偶尔还会改变接口。

共8页: 上一页 1 [2] [3] [4] [5] [6] [7] [8] 下一页

上一篇:对Linux服务器四种级别入侵简述及反击措施   下一篇:教你在MySQL 5.0以上版本中配置主从库

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·教你在MySQL 5.0以上版本中配置主从库
·lighttpd PHP(FAST-CGI) MySQL的学习笔记
·适宜做简单搜索的MySQL数据库全文索引
·Linux下检查MySQL的Slave是否正常
·Ubuntu下MySQL的手工安装
·个人经验总结:完全卸载MySQL数据库5.0
·如何在Unix系统环境下安装MySQL数据库
·初学者必读:MySQL数据库常见问题汇总
·初学者在使用MySQL时必须了解的注意事项
·MySQL数据库在网络安全方面的一些防御措施
·MySQL中两种快速创建空表的方式的区别
·Lunix环境下MySQL数据库的自动备份脚本
·实例讲解如何利用crontab定时备份MySQL
·讲解MaxDB数据库和MySQL数据库的主要差别
·讲解MySQL数据库的数据类型和建库策略
·将MySQL 5.0下的数据导入到MySQL 3.23中
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·适宜做简单搜索的MySQL数据库全文索引
·lighttpd PHP(FAST-CGI) MySQL的学习
·教你在MySQL 5.0以上版本中配置主从库
·Linux下检查MySQL的Slave是否正常
·Ubuntu下MySQL的手工安装
·个人经验总结:完全卸载MySQL数据库5.0
·如何在Unix系统环境下安装MySQL数据库
·初学者必读:MySQL数据库常见问题汇总
·初学者在使用MySQL时必须了解的注意事
·MySQL数据库在网络安全方面的一些防御
·MySQL中两种快速创建空表的方式的区别
·Lunix环境下MySQL数据库的自动备份脚本
  阅读排行
·Linux 安装 Mysql
·如何在Linux系统中安装MySQL
·在Linux 环境下安装 Mysql
·在Linux上安装MySQL Server 5.0
·图形化管理MySQL更轻松
·[Mysql]IIS+mysql+php相关知识介绍
·你应该知道的10个MySQL客户启动选项
·MySQL创始人David Axmark 访谈实录
·[MySQL]入门学习从安装入门到学习操作
·如何启动与停止MySQL的服务器
·Linux系统上安装MYSQL数据库的方法
·Heartbeat_2.0.3配置MySQL5.0.8集群
·《数据结构(C语言版)》 电子书籍下载
·MySQL 5.0新特性教程 存储过程:第一讲
·MySQL中文参考手册-创造并使用数据库
网摘收藏: