ORACLE数据库19c新特性-自动索引管理

Automatic indexing是Oracle Database 19c开始新增加的特性,从字面上很容易理解,就是依据应用负载的变化自动/动态地进行索引的管理任务,比如创建(create index)、重构(rebuild index)和删除(drop index),从而提高数据库性能,这个特性也是Oracle自治数据库云服务自我优化的一个基础。

 

索引从一开始就是数据库性能的一个基本特性,尽管在并行、分区、压缩、物化视图以及内存列等其他性能特性方面有了很大的进步,但索引仍然是OLTP甚至OLAP中都离不开的关键特性。过去的经历大家都有深刻的体会,创建合适的索引其实是蛮有挑战的,它需要我们对数据模型、应用程序以及数据分布有深入的了解,还需要对数据库系统的内部结构有一定的了解(例如查询优化、缓存区管理等),同时辅助各种Advisor(比如Index Advisor, Partition Advisor, In-Memory Advisor等),靠经验丰富的DBA来完成。

 

现实中,无论优化人员多么的技术熟练,但往往当对数据模型、应用程序代码或数据分布进行修改时,他/她却很少修改索引的选择,所以我们经常会看到很多不必要的索引或不合适的索引导致的性能问题。Automatic indexing将这个复杂的处理实现了自动化,基于手动SQL调优的常用方法,通过构建内置的专家系统,自动捕获SQL(Capture)、识别候选索引(Identify Candidates)、验证(Verify)、决策(Decide)、在线验证(Online Validation)、监控(Monitor)等方法将索引的管理实现了自动化,这个过程并不简单。是不是很酷?

 

:Automatic indexing特性对于on-prem环境仅支持Oracle Exadata平台,对于Oracle Cloud各个Cloud Edition都支持。

 

•Automatic indexing 提供如下功能

1)定期在预定义的时间间隔内在后台运行自动索引过程
2)分析应用程序工作负载,并根据分析报告相应地创建必要的新的索引,并删除现有性能不佳的索引,以提高数据库性能
3)重构由于表分区维护操作(比如ALTER table MOVE)而被标记为不可用的索引(unusable index)
4)提供PL/SQLAPIs,用于配置数据库中的自动索引和生成与自动索引操作相关的报告。

 

 说明

1)当前版本Auto indexes 是local B-tree 索引,将来或许也会支持bitmap、FBI、Partial、domain等类型,我们拭目以待吧。

2)支持分区和非分区表,不支持临时表。

 

•Automatic indexing 是如何工作的?

自动索引基于手动SQL调优的常用方法,它不断评估执行的SQL和基础表,以确定要创建哪些索引以及可能删除哪些索引。它通过专家系统完成此任务,该系统验证索引可能做出的改进,并在创建之后验证所做的假设。然后它使用强化学习来确保它不再犯同样的错误。最重要的是,随着数据模型和访问路径的变化,Oracle数据库19c能够随着时间的推移进行调整。

 

Automatic Indexing Process(自动索引过程)以后台服务进程每隔15分钟运行一次,并执行如下任务:

  1. 识别自动索引候选项

      通过捕获SQL历史到SQL repository(包括SQL,执行计划,绑定变量,统计信息等),识别SQL语句中用到列的使用情况来标识自动索引候选项。

  2. 为自动索引候选项创建invisible的自动索引

      Invisible Indexes是11g中提出的新功能,缺省对优化器是不可见的,也就是说不会影响到用户既有的SQL语句。而且

  3. 根据SQL语句验证不可见的自动索引

      如果通过使用这些自动索引提高了SQL语句的性能,那么会将这些索引配置为可见索引,以便在SQL语句中使用它们。
       如果使用这些索引不能提高SQL语句的性能,则将这些索引置为unusable的索引,并将对应的SQL语句列入“黑名单”。unusable的索引稍后会被自动索引过程删除。被列入“黑名单”的SQL语句将来不允许使用自动索引。

  4. 清除unused auto indexes

      对于长时间不使用的auto indexes会自动进行清除工作。缺省是373天,可以使用DBMS_AUTO_INDEX.CONFIGURE过程来配置数据库中保留未使用的自动索引的时间段。

• 在数据库中配置AutomaticIndexing
   这个动作通过DBMS_AUTO_INDEX.CONFIGURE过程来完成。
   1、启用和禁用Automatic Indexing特性

       ◊启用自动索引,并将任何新的自动索引创建为可见索引(visible indexes),以便在SQL语句中使用

 SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_MODE','IMPLEMENT');
 

       ◊启用自动索引,但将任何新的自动索引创建为不可见索引(invisible indexes),所以不能在SQL语句中使用

 SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_MODE','REPORT ONLY');

 

       ◊禁用自动索引,这样就不会创建新的自动索引,并禁用现有的自动索引。这也是缺省模式。

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_MODE','OFF');

  2、指定哪些Schemas可以使用Automatic Indexing

       当在上一步启用Automatic Indexing特性后,缺省情况下所有的Schemas都可以使用Automatic Indexing。管理员可以根据需要允许哪些schema使用自动索引。

       比如:以下语句将SH和HR用户添加到排除列表中,这样SH和HR用户就不能使用自动索引:

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_SCHEMA', 'SH', FALSE);
SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_SCHEMA', 'HR', FALSE);

       后期如果又想让某个用户使用自动索引,比如HR,可以通过如下语句来设置

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_SCHEMA', 'HR', NULL);

       恢复到缺省(也就是所有Schema都可以使用自动索引)

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_SCHEMA', NULL, TRUE);

  3、为unused auto indexes指定保留期

       下面的语句将未使用的自动索引的保留期设置为90天。       

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_RETENTION_FOR_AUTO', ' 90');


下面的语句将未使用的自动索引的保留期重置为默认值373天。        

SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_RETENTION_FOR_AUTO', NULL);

  4、为unused 非自动索引(non-auto indexes)指定保留期

       就是为我们手动创建的unused的索引指定一个保留期,缺省情况下,Automatic Indexing Process(自动索引过程)不会删除unused手动创建的索引。

       通过如下过程,指定一个unused手动索引保留期,比如60天,那么到期后,将会被Automatic Indexing Process(自动索引过程)清除。

       SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_RETENTION_FOR_MANUAL', '60');
        恢复到默认值(也就是不给unused 手动索引指定保留期,Automatic Indexing Process不会删除这些索引)
        SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_RETENTION_FOR_AUTO',NULL);       

  5、为automatic indexing logs指定保留期

       缺省是31天,如下示例表示保留60天

       SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_REPORT_RETENTION', '60');

       恢复到缺省

       SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_REPORT_RETENTION', NULL);

       注意:Automatic indexing reports的生成依赖于automatic indexing logs。所以,当过了automatic indexing logs的保留期后,相应的automatic indexing reports就不能生成了。

  6、指定一个表空间存放Auto Indexes

       缺省情况下,使用当前数据库的缺省持久表空间。可以通过如果配置指定为其他表空间:

       SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_DEFAULT_TABLESPACE', 'MYAUTOTBS');

       说明:对于使用缺省持久表空间存放Auto Indexes的情况,可以通过类似如下过程来指定一个空间限额(可以使用到20%),缺省是50%:

                SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_SPACE_BUDGET', '20');

  7、指定一个临时表空间存放临时Auto Indexes结构

      缺省情况下,使用当前数据库的缺省TEMP表空间。可以通过如果配置指定为其他表空间:

       SQL> EXEC DBMS_AUTO_INDEX.CONFIGURE('AUTO_INDEX_TEMP_TABLESPACE', 'MYAUTOTBS_TEMP');

 

生成Automatic Indexing报告

  通过DBMS_AUTO_INDEX包的REPORT_ACTIVITY和REPORT_LAST_ACTIVITY函数可以生成AutomaticIndexing Reports。

  

比如生成指定时间范围的自动索引报告:

  set serveroutput on

  declare 
       report clob := null;
   begin
       report := DBMS_AUTO_INDEX.REPORT_ACTIVITY(
                   activity_start => TO_TIMESTAMP('2019-02-17', 'YYYY-MM-DD'),
                    activity_end => TO_TIMESTAMP('2019-02-17', 'YYYY-MM-DD'),
                              type => 'HTML',          --支持TEXT、HTML、XML 3中格式,缺省是TEXT
                          section => 'SUMMARY',   
                              level => 'BASIC');

      dbms_output.put_line(report);
   end;

  /

关于这2个函数的各个参数的详细说明,参看Oracle Database PL/SQL Packages and Types Reference。

 

生成最近一次的自动索引报告:

  set serveroutput on

  declare
       report clob := null;
   begin
       report := DBMS_AUTO_INDEX.REPORT_LAST_ACTIVITY(
                               type => 'HTML',
                           section => 'SUMMARY +INDEX_DETAILS +ERRORS',
                               level => 'BASIC');

      dbms_output.put_line(report);
  end;

 /

•Automatic Indexing相关的数据字典

  DBA_AUTO_INDEX_CONFIG                          --19.1新增视图,描述当前自动索引的配置
   DBA_INDEXES/ALL_INDEXES/USER_INDEXES   --新增加的AUTO列标识是自动索引(YES)还是手动索引(NO)

  DBA_AUTO_INDEX_EXECUTIONS                  --显示历史自动索引任务执行
  DBA_AUTO_INDEX_STATISTICS                   --显示与自动索引相关的统计信息

  DBA_AUTO_INDEX_IND_ACTIONS                --显示在自动索引上执行的操作

  DBA_AUTO_INDEX_SQL_ACTIONS                --显示在SQL上执行的验证自动索引的操作

 

•Automatic Indexing初体验

 

  1、检查缺省Automatic Indexing配置  

640?wx_fmt=png

 

  2、准备点测试数据

       PDB1@ZRP>create table test as select * from dba_objects;
        Table created.
        PDB1@ZRP>insert into test select* from test;
        72397 rows created.
        PDB1@ZRP>insert into test select* from test;
        144794 rows created.
        ...   ---反复插入

       PDB1@ZRP>update test set object_id=rownum;
        2316704rows updated.
        PDB1@ZRP>commit;
        Commit complete.
        PDB1@ZRP>

  

3、启用Automatic Indexing

 

640?wx_fmt=png

 

4、执行测试SQL

 

      PDB1@ZRP>select object_name from test where object_id=1;
       PDB1@ZRP>select object_type from testwhere object_id=123;
       PDB1@ZRP>select created from test whereobject_id=345;
       ...

  

5、检查Automatic Indexing Process的执行情况(15分钟以后)

 

640?wx_fmt=png

 

640?wx_fmt=png

 

640?wx_fmt=png

 

  6、检查下Automatic Indexing 报告

     这里以html格式输出

       set serveroutput on
        declare
               report clob := null;
        begin
               report := DBMS_AUTO_INDEX.REPORT_ACTIVITY(
                       activity_start => TO_TIMESTAMP('2019-02-17 22:51:00', 'yyyy-mm-ddhh24:mi:ss'),
                       activity_end => TO_TIMESTAMP('2019-02-17 22:53:07', 'yyyy-mm-dd hh24:mi:ss'),
                                 type => 'HTML',
                             section => 'ALL',
                                level => 'ALL');
               dbms_output.put_line(report);
        end;
        /

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值