好多初级DBA很喜欢用reuildonline重建索引,他们认为这样做不会影响业务。
创新互联公司是一家专业提供山西企业网站建设,专注与成都做网站、网站设计、成都h5网站建设、小程序制作等业务。10年已为山西众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。曾经发生的几次故障,在业务用的时候,rebuild online索引,导致大部分业务无法使用,数据库hang.
其实rebulid 索引很简单
drop index index_name
Alter indexindex_name rebuild;
Alter indexindex_name rebuild online;
作为DBA,对生产系统执行任何操作时,仅仅懂这些还是远远不够的,需要明确如下几点
1、执行该命令会对业务有啥影响,是不是业务时间,如果是一定不要进行类此操作。因为在大对象中创建索引时不仅需要较大temp表空间,而且是DDL操作,基于表原有索引SQL语句的执行计划都会发生变化,导致大量的解析导致消耗大量的cpu资源。
2、如果删除或者索引失效后,会出现大量的全表扫描。这不仅对系统I/O产生压力,对CPU、内存方面压力也大。
3.要理解rebuild和rebuildonline 的区别。
alter index rebuild online实质上是扫描表而不是扫描现有的索引块来实现索引的重建.
alter index rebuild 只扫描现有的索引块来实现索引的重建。
rebuild index online在执行期间不会阻塞DML操作,但在开始和结束阶段,需要请求模式为4的TM锁。因此,如果在rebuild indexonline开始前或结束时,有其它长时间的事物在运行,很有可能就造成大量的锁等待。也就是说在执行前仍会产生阻塞,应该避免排他锁.如果在业务期间做,可能会导致 online执行很长时间,在 rebulid index online 的时候走的是 full table scan,这时候需要排序,消耗大量的temp空间,rebuild online需要2倍的索引空间。
而rebuild index在执行期间会阻塞DML操作, 但速度较快,rebulidindex 走的index ffs,而ffs搜索的顺序是根据leaf block的物理存储顺序相关,也需要排序。也会消耗大量的临时表空间。
总之不要在业务期间进行DDL(rebulid 及rebulid online index),或者使用DROP INDEX creat index 来代替rebuild index。
分享标题:rebuildonline请慎用-创新互联
本文网址:http://lswzjz.com/article/dojspd.html