Monty说MySQL的优化(一)

2016-02-19 18:02 7 1 收藏

下面请跟着图老师小编一起来了解下Monty说MySQL的优化(一),精心挑选的内容希望大家喜欢,不要忘记点个赞哦!

【 tulaoshi.com - 编程语言 】

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

  硬件

  操作系统/软件库

  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)。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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

  四、优化操作系统

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

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

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

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

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

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

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

  五、选择应用编程接口

  PERL

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

  适宜快速原型。

  应该使用DBI/DBD接口。

  PHP

  比PERL易学。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  使用比PERL少的资源。

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

  C

  MySQL的原生接口。

  较快并赋予更多的控制。

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

  C++

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

  仍在开发中

  ODBC

  运行在Windows和Unix上。

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

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

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

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

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

  ODBC

  运行在Windows和Unix上。

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

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

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

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

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

  JDBC

  理论上可在不同的操作系统何时据库间移植。

  可以运行在web客户端。

  Python和其他

  可能不错,可我们不用它们。

来源:http://www.tulaoshi.com/n/20160219/1616651.html

延伸阅读
同时在线访问量继续增大 对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机 或者时不时的服务器卡一下 这个问题曾经困扰了我半个多月MySQL使用是很具伸缩性的算法,因此你通常能用很少的内存运行或给MySQL更多的被存以得到更好的性能。 安装好mysql后,配制文件应该在/usr/local/mysql/share/mysql目录中,配制文件有几个,有my-huge.cn...
标签: MySQL mysql数据库
       数据库系统是管理信息系统的核心,基于数据库的联机事务处理(OLTP)以及联机分析处理(OLAP)是银行、企业、政府等部门最为重要的计算机应用之一。从大多数系统的应用实例来看,查询操作在各种数据库操作中所占据的比重最大,而查询操作所基于的SELECT语句在SQL语句中又是代价最大的语句。举例来说,如果数...
当你执行管理员优化的时候,应该紧记以下规则: · 访问内存中的数据快于访问磁盘上的数据。 · 尽量把数据保存在内存中可以减少磁盘操作。 · 保留索引中的信息比保留数据记录的内容更重要。 我们在后面将讨论如何应用这些规则。 增加服务器缓存的大小。服务器拥有很多参数(系统变量),你可以改变这些参数来影...
但请注意,下面的优化并不是完全的。MYSQL实施了许多优化,但我没时间全部测试. MySQL的一些优化列在下面: 删除不必要的括号: ((a AND b) AND c OR (((a AND b) AND (c AND d)))) - (a AND b AND c) OR (a AND b AND c AND d) 常数调入: (ab AND b=c) AND a=5 - b5 AND b=c AND a=5 删除常数条件: (B=5 AND B=5) OR (B=6 AND 5=5) O...
在发布一个选择行的查询时, MySQL进行分析,看是否能够对它进行优化,使它执行更快。本文我们将研究查询优化程序怎样工作。更详细的信息,可参阅MySQL参考指南中的“Getting Maximum Performance from MySQL”,本文描述了MySQL采用的各种优化措施。(http://www.mysql.com/ 处的MySQL联机参考指南在不断地更新。) MySQL查询优化程...

经验教程

830

收藏

57
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部