- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
网速再怎么快,程序语言如JSP 再怎么先进,如果你的数据库没有优化好,查询一个几百条
数据库就很吃力的话,那么网站建设是失败的,做好网站的优化,数据库是关键,大多的网
站都是动态的,需要实时连接数据库,那么数据库的优化问题就值得大家去了解了,下面长
沙久安网络公司为你分析数据库如何优化。
那什么是数据库优化了,数据库优化,简单地说,是根据一开始网站数据库设计而进行的优
化。开始网站设计的时候,可能考虑的不是很全面。后期网站访问量增加,出现页面数据显
示过慢,程序执行效果差等现象。优化数据库从而加速数据读取,页面访问速度加快
A.sql 语句优化,指对查询语句,增,删,改等进行优化
B.增加索引,索引需要在数据量超大的时候加,一般不建议加,因为每增加一条记录会索引
一次,添加时慢,可以到了一万条或几万,一次生成索引,就方便多。
B.程序优化,指如 ASP ,PHP ,JSP 等程序对数据库的接口语句优化。
数据库优化,只有优化了数据库,使其性能提升,运用数据库时才能方便快捷。目前
web2.0 的程序,很大瓶颈是数据库的吞度量。不过,如何才能确定系统的瓶颈是数据库呢,
因为只有确定数据库是整个系统的瓶颈,我们才有必要去优化他,毕竟,还有这么多需求等
待我们去做。
知道数据库是瓶颈了,如何来进行优化呢?
1 我们第一个想到是看看数据库的容量是不是太大了,如果数据库表太大的话,索引文件也
会比较大,每次的更新操作就会更加的费时。需要考虑进行分库和分表了。
分库分表按照一定的规则来对数据库中的记录进行分区来存储,一方面可以做到一定的负载
均衡,将请求平分下来,每个区段去独自承受;另一方面,分库分表可以使我们存储和操作
更多的数据。
不过分库分表需要多之前基于单库的程序进行修改,存在一定的风险,因此,在程序设计之
初就应该考虑到分库分表的需要,最好是将数据库操作层独立出来,便于扩展和更改。
2 如果数据库表不是很大,但是查询慢的话,我们需要检查一下我们的 sql 查询语句,利用
mysql 的 explain 语句看看是不是使用了索引,如果没有使用索引,那我们需要在相应的字
段上建上索引,反复的使用 explain ,寻找到个一个合适的索引。
确定数据库是瓶颈?
1 如果程序设计良好,有一个数据库操作逻辑层,可以从这个层的统计数据看到每个请求花
费的时间,如果平均时间已经不能让你容忍的话,数据库已经是瓶颈了。
2 在数据库的服务器上使用 top 命令,看看 mysql 服务器占用资源的情况,看看机子的平均
负载。
如果服务器的平均负载已经很高,mysql 占用了块 100%的 cpu 资源,说明 mysql 服务器很
忙了。
3 在数据库服务器上使用 iostat 命令,看看磁盘 IO ,如果block 住的操作比较多的话,说明
数据库操作还是过于频繁了,磁盘都响应不急了。
4 建议打开 mysql 的慢查询日志,这样grep select 看一下日志中的慢查询的数量,如果数量
较多,说明慢查询的数量很多,需要进行调整了。
5 如果有一天数据库无法插入了,需要检查一下数据库表是不是过大了。32 位的操作系统
上一个表最大的容量是 2^32 这么大。不过还是建议增加一个数据库操作的逻辑层,在数据
库操作的前后记录下操作的时间,进行统计上报,利用监控程序来报警相关负责人,这样可
以及早的知道数据库是瓶颈,提前做出优化。
建索引时需要考虑:
1)数据库的索引要做到越少越好:因为每次更新都需要更新索引,索引过多就会降低写入的
速度
2)最窄的字段放在键的左边:这样提高了索引中每一个点的基数,带来更好的索引读写性能
3)尽量避免 file sort 排序、临时表和表扫描:对于大表,全表扫描会导致大量的磁盘 IO 的操
作,会导致操作非常的缓慢
4)对于大表,尽量不要将索引建在字符串类型的列上,字符串的匹配是很费时的,需要付出
很高的性能代价,如果一定有必要,建议对字符串列进行 hash 后取一个整形的值来进行索
引。
3 如果更新操作有点慢,而读操作的响应要求不需要很及时的话,可以考虑利用 mysql 的主
从热备来分担读写的压力。
毕竟对数据库的操作,写少读多。因此,我们将对数据库的写操作放到 mysql 的主服务器上,
利用 mysql 的热备,我们在备份的数据库服务器上进行读操作,由于可以有多个热备
mysql ,于是可以将读操作分布在多个热备上面,从而将读操作均衡开来,提高读操作的性
能。
4 缓存的使用
缓存是一切后台程序的根本,因为 80%的请求是对应20% 的数据,我们只需要少量的内存
将 20% 的数据
文档评论(0)