免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2582 | 回复: 0
打印 上一主题 下一主题

SLBPS系统维护之一 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-01 06:11 |只看该作者 |倒序浏览
前言

    本人有幸参加了公司SLBPS的上线与维护工作,回想近半年来的上线与维护工作,其中有很多感慨,最大的感慨就是累~~所谓少壮不努力,老大做IT,各种滋味,不可与人道也。
    slbps作为全国范围发布的大型分布式系统,是公司在实施数据集中与开发中心一个战略性的部署之一。作为维护人员,不仅需要数据公司产品与业务,也需熟悉相关技术实现细节:数据库,中间件,广域多域,软件工程,小型机,unix系统,运营管理等等,每一个开一个专题都是令人望而生畏的大题目。

    slbps客户端:VB
         中间件:Tuxedo
         数据库:informix
         服务器:hp_unix
         
                       专题一 基于索引的SQL优化问题(参考)
   客服业务受到SQL语句的影响非常大,在上规模的应用场景下,往往因为一个小的SQL语句不够优化,导致数据库性能急剧下降,小型机idle所剩无几,应用服务器断连、超时,严重影响业务的正常运行。因此,低效的sql是我们维护人员所深恶痛绝的。数据库的优化方法有很多种,在应用层来说,主要是基于索引的优化。
    我们领导说的最多一句话:这帮丫的,写的啥sql,都不走索引。或者是:这丫的,这张表居然没有建索引...囧rz..事实上,给表建立必要的索引是最为考一个数据管理员功底的技术活之一,因为,难点是如何判断这些索引对数据库的性能有没有帮助。具体到方法上,必须对应用程序中所有的sql语句非常熟悉,从中统计出对性能有影响的sql,分析,归纳出作为where条件子句的字段与其组合方式,这个可以判断哪一个字段应该建索引;其次,必须数据应用程序,以此了解哪些表是频繁操作的表,哪些表经常与其它表连接,哪些表数据量比较大,大表中数据分布情况如何等,常用的规则:
    1、表的主键、外键必须有索引;
    2、数据量超过300的表应该有索引;
    3、经常与其他表进行连接的表,在连接字段上应该建立索引;
    4、经常出现在Where子句中的字段,特别是大表的字段,应该建立索引;
    5、索引应该建在选择性高的字段上;
   6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引;
   7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替:
        A、正确选择复合索引中的主列字段,一般是选择性较好的字段;
     B、复合索引的几个字段是否经常同时以AND方式出现在Where子句中?单字段查询是否极少甚至没有?如果是,则可以建立复合索引;否则考虑单字段索引;
        C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段索引;
        D、如果复合索引所包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的字段;
       E、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引;
   8、频繁进行数据操作的表,不要建立太多的索引;
  9、删除无用的索引,避免对执行计划造成负面影响;
   以上是一些普遍的建立索引时的判断依据。一言以蔽之,索引的建立必须慎重,对每个索引的必要性都应该经过仔细分析,要有建立的依据。因为太多的索引与不充分、不正确的索引对性能都毫无益处:在表上建立的每个索引都会增加存储开销,索引对于插入、删除、更新操作也会增加处理上的开销。 另外,过多的复合索引,在有单字段索引的情况下,一般都是没有存在价值的;相反,还会降低数据增加删除时的性能,特别是对频繁更新的表来说,负面影响更大。


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/80630/showart_1271007.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP