当前位置:首页百负载之SQL数据库的优化 举报文章

百负载之SQL数据库的优化

作者:admin    来源:用户投稿    时间:2015.6.11   

  在考虑一个网站如果承载日百甚至千pv时,我们往往本能的往两个方向考虑:静态化及分布式。 固然,对于新浪等门户类型的网站来说,静态化+读写分离及分布式,可以解决大多数的问题。可是我们面临的更多的,可能是大数据+高并发+实时读取,而静态化的固定性便很难解决这个问题。

  比如矮个芝麻最近接到的一个电子商务类的网站,流量大,数据量大,同时要求实时更新,因为首页以及内容页往往每时每刻都在变化着。 这个时候我们就不得不查询数据库,也就需要针对数据库作出一些特定的优化。

  优化建议:

  1)表结构的优化

  通过对表结构的优化,往往可以直接的降低数据库的压力。常见的方法比如建索引,拆表,适当冗余扁平化。 索引的作用最为直接,通过B+树轻松实现类似于将一张表划分为几百张表的效果,在进行查询时,往往链表查询需要十次才能查询到的数据,加了索引之后或许只需要四次就可以解决。

  当然不要过分的增加索引,因为会一定程度上增加数据库的负担。 同时说一个很有意思的问题,如何实现身份证查询系统?我们往往知道,身份证的前几位决定了这个人的所在地,出生年月等可见信息,然后才是几位随机数。而且应该有发现一个问题,那就是只有在户口所在地才能登记身份证,这就是拆表查询。公安系统只需要查询当地数据库下该生日及随机数是否有重复,就可以判断全国是否有重复的身份证了。

  最常用的方法是,将一个月内的活跃用户单独设为一个表,这样每次用户登录,其实只是查询了当月的用户,可以有效的提高查询效率.

  2)sql语句的优化

  sql语句的优化往往要直白很多,就是尽量减少like查询,关联查询等资源消耗比较大,查询量比较大的sql语句,即可,整理了几条如下:

  1.减少不必要的like查询,尽量通过建关键词表实现like查询的效果

  2.减少关联查询,尽量通过左链接右链接的形式实现查询

  3.复杂的查询语句使用储存过程解决.

  4.减少不必要的查询.

  5.避免在索引列上使用IS NULL和IS NOT NULL

  6.尽量避免使用耗费资源的操作:带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎

  7.不要使用SELECT *,尽量指明要显示的列

  8.不要使用INSERT导入大批的数据 请不要这样做,除非那是必须的。使用UTS或者BCP,这样你可以一举而兼得灵活性和速度。

  3)程序段的优化尤为重要

  程序段根据不同的用户需求进行优化,尤为重要.

  最常见的案例就是,当查询列表时,只查询出标题名及简介就可以解决问题.当用户打开该文章后,才会查询该文章的文章内容,评论,发表人信息等关联表的内容.这样可以在很大程度上降低程序的负担.

  尽量通过ajax,在有必要的情况下进行后台查询,而不是在打开页面的时候就进行相关的查询.

  另外,最为重要的一点就是,尽量实现静态化.

  一般对于cms类型的网站来说,静态化可以解决大多数的问题.而后需要查询数据库的无非就是搜索,用户会员中心的相关操作.

  而搜索是可以通过读写分离异步操作的,这样就可以有效的降低服务器的压力.

  当然,还有更多更有效的方法,只是今天突然兴起整理一下,有问题可以和矮个芝麻一起沟通哦~

好文打赏,给Ta鼓励
扫一扫用手机阅读本文
Tags:百万  负载  数据  数据库  优化  
  • 相关搜索
图片推荐
    微商该怎么做?方向大于选择

    微商该怎么做?方向大于选择

    刚在朋友圈玩了一个游戏,老掉牙的游戏,集赞点赞够多就分享一篇刚收获的干货,大伙很给力,一会就几十个赞了,都不好意思不写了,连夜不知疲惫赶稿啊!同志们要认真看啊!别辜负我的一片苦心啊!  是这样今天请了
    即将到来的百度搜索“大地震”,超越黑色6.28K站事件

    即将到来的百度搜索“大地震”,超越黑色6.28K站事件

    六月以至,可喜的是百度网页搜索质量白皮书即将发布,可悲的是百度会对一些质量低的站点给予降权,这对于站长来说,不论是企业、个人或第三方提供商都会是一件可喜可悲的事。而今年不同于往年,既然百度五月中旬发布
    戳穿SEO谎言:被高估的PR值

    戳穿SEO谎言:被高估的PR值

    国内大部分的主流SEO都把网页的PR值看的太过重要了,以至于明显高估甚至误解了PR的作用。比如,交换友情链接要看PR,判断网站质量要看PR,SEO的成效标准要看PR,PR高低简直成了判断一个站长或者S
    浅谈中小网站的SEO思路

    浅谈中小网站的SEO思路

    中小网站的站长通常都要面对资金限制这一问题,从而制约了网站从百度竞价、其他推广渠道获得流量,因而只好采用保守经济的seo方式来增加人气和流量。可能有不少站长会羡慕大型网站的丰富资源,但熟悉seo的人都
    新站如何获取长尾词的流量

    新站如何获取长尾词的流量

    长尾词对于小型企业站来说是非常珍贵的资源,因为小型企业的目标词流量非常有限即使排名做到第一名百度竞价也已经截取了很大一部分流量,自然排名可获得的流量非常细微。长尾词布局就显得尤为重要,今天易科seo以
    精细之外 邮件营销更要因行业而异

    精细之外 邮件营销更要因行业而异

    关于邮件营销,我想大家肯定都不陌生,相对于做广告或是软文营销,邮件营销的方式方法虽然有点像苦力活,但是一封好的邮件仍然会给自己带来比较可观的转化率,这点毋庸置疑。可是相比于微信以及微博推广,我们在做邮
    新手开店卖什么赚钱

    新手开店卖什么赚钱

    很多朋友对于网赚的理解还停留在淘宝开店的层面,诚然,淘宝开店确实是属于网赚的一种,但是目前已经不是黄金时代,淘宝市场已经趋近于饱和,新手销售普通的商品,很难成功,接下来,简单的与大家分享几种适合新手操
    怎么开网店步骤与流程?详细淘宝开店教程教你如何开

    怎么开网店步骤与流程?详细淘宝开店教程教你如何开

    怎么开网店步骤与流程?详细淘宝开店教程教你如何开 最近越来越多的人看到了电子商务的迅速发展,都想在淘宝开一家网店。谈到开网店,很多人都没有经验,也不知道如何去注册网店。网上各种搜索查找,也没能找到一份
你是怎么知道非凡网赚网的?
  •   
  • 联系QQ 邮箱:976382653@qq.com 微信:976382653
    在线留言
    发布软文
    广告自助购
    文章调用
    常见问题
    保存到桌面