Overview of Oracle 9i
Performance Tuning
• To design a system and applications to realize performance gains we perform tuning.
   – There are basically two forms of tuning
      • Speed: Short response time
      • Higher scalability : Higher load at a comparable response time
• Create a good initial design.
   –   Fewer waits
   –   Improved database availability
   –   Improved memory utilisation
   –   Improved instance hit percentages.
   –   Keep disk I/O to minimum.
• List tuning problems
• Decide between performance and safety.
 Proactive Tuning Considerations
      During Development
During Development of a new system,the
   following order of tuning implementation is
   recommended.
• Tune the design.
• Tune the application.
• Tune memory.
• Tune I/O.
• Tune contention.
• Tune the operating system.
  Tuning Steps During Production
• Locate the bottleneck by using tools
  like STATSPACK,UTLBSTAT or OEM.
• Determine the reason for the bottleneck.
• Resolve the cause.This could mean
  changing the size of a member of SGA.
• Check that the bottleneck has been
  resolved.
Performance Versus Safety
       Trade-Offs
Factors that affect performance:
• Multiple control files
• Multiple redo log members in a group
• Frequent checkpointing
• Backing up datafiles
• Performing archiving
• Block check numbers
• Number of concurrent users and
   transactions
There is always a trade-off with performance.The safer the
DBA makes the database,the slower it runs.
               Alert.log
• Alert.log consists of chronological log of
  messages and errors.
• Maintain and check alert.log file.Regularly
  remove and trim the file.
  – Background_dump_dest
• The file contains the check point start and
  end time information which can be used
  for tuning
Tuning Using the alert.log File
The alert.log file contains the following
   information which can be used in tuning the
   database:
• Checkpoint start and end times
• Incomplete checkpoints
• Time to perform archiving
• Instance recovery start and complete times
• Deadlock, and timeout errors.
These values are logged only if
   LOG_CHECKPOINTS_TO_ALERT=TRUE.
    Background Processes
         Trace Files
Oracle maintains Background Process Trace
  Files.
 • The Oracle server dumps information
   about errors detected by any background
   process into trace files.
• Oracle Support uses these trace files to
   diagnose and troubleshoot.
• These files do not usually contain tuning
   information.
             User Trace Files
User trace files can be generated by server
   processes at the user’s or DBA’s request.
• Server process tracing can be enabled or disabled at the session
   or instance level.
• A user trace file contains statistics for traced SQL statements in
   that session.
Sql>EXECUTE dbms_system.set_sql_trace_in_session(8,12,TRUE);
SQL>Alter SESSION set sql_trace=TRUE;
• User trace files are created on a per server process basis.
• User trace files can also be created by:
   – Backup control file to trace
   – Database SET EVENTs
    Using SQL Trace and TKPROF
To use SQL trace and TKPROF:
• Set the initialization parameters.
• Alter session set SQL_Trace = true
• Run the application.
• Alter session set SQL_Trace = false
• Format the trace file with TKPROF.
• Interpret the output.
The trace file .trc is determined by the user_dump_dest
   initialization parameter.TKPROF also reports the
   Library cache misses.
 Sort=options          The order of the sort
                       statements
 Print=n               Stores the first n statements
                       to the output file.
 Explain=user/password Run explain plan
 Insert =filename               Causes the output to be
                                formatted as a series of
                                insert statements
 Sys=no                         Ignores recursive sql
                                statements run as a user sys
When you specify the explain plan ,TKPROF logs onto the
database and uses the information available at the time that the
utility was run.
        TKPROF Statistics
• Count: Number of execution calls
• CPU: CPU seconds used
• Elapsed: Total elapsed time
• Disk: Physical reads
• Query: Logical reads for consistent read
• Current: Logical reads in current mode
• Rows: Rows processed
               Sql* Plus Autotrace
• Sql* Plus Autotrace instead of SqlTrace.
   –   Need not format
   –   Automatically displays execution plan.
   –   Create the PLAN_TABLE from utlxplan.sql
   –   Create plustrace role by executing plustrce.sql
   –   Set Autotrace to the level
        •   Off-default
        •   On-includes optimizer execution plan & execution Statistics
        •   On explain –shows only execution plan
        •   On statistics – only execution statistics
        •   TRACEONLY-same as On but suppress the users query output.
• Delete all the existing trace files from
  $home/admin/udump.
• Connect to any user.using alter session set
  SQLTrace=true.
• Run some select on a big table.
• Disable the trace.
• Then format the trace using TKPROF.
• Use sys=no explain=user/user.
      Views, Utilities, and Tools
Tools, and views, that are available to the DBA
   for determining performance:
• V$xxx dynamic troubleshooting and performance
   views
• DBA_xxx dictionary views
• STATSPACK.Collect statistics over a period of time and store in a
  database.It also generates info on SQL statements in the Library Cache.
• utlbstat.sql and utlestat.sql scripts
• Enterprise Manager
• Oracle wait events
• Oracle diagnostics and tuning packs
  Dynamic Troubleshooting
   and Performance Views
V$ views:
• Based on X$ tables
• Listed in V$FIXED_TABLE
X$ tables:
• Not usually queried directly
• Dynamic and constantly changing
• Names abbreviated and obscure
• Memory structures that hold instance info.
•Dynamic and so contents keep changing.
Populated at startup and cleared at shutdown
 Topics for Troubleshooting and
             Tuning
System wide Statistics                             Session-Related Statistics
Memory
• V$BUFFER_POOL_STATISTICS     Disk                  •User/Session
 T/P                           •V$DATAFILE T/P
• V$DB_OBJECT_CACHE T                                •V$LOCK P
                               •V$FILESTAT T/P       •V$OPEN_CURSOR T
• V$LIBRARYCACHE P
• V$ROWCACHE P                 •V$LOG T              •V$PROCESS T
• V$SYSSTAT T/P                •V$LOG_HISTORY T      •V$SORT_USAGE T/P
• V$SGASTAT P                  •V$DBFILE T/P         •V$SESSION T/P
Instance/Database              •V$TEMPFILE P
• V$DATABASE T                                       •V$SESSTAT T/P
                               •V$TEMPSTAT P         •V$TRANSACTION T
• V$INSTANCE T
• V$OPTION T                                         •V$SESSION_EVENT T/P
• V$PARAMETER T/P              Contention            •V$SESSION_WAIT T/P
• V$BACKUP T
                               •V$LOCK T/P           •V$PX_SESSTAT P
• V$PX_PROCESS_SYSSTAT T/P
• V$PROCESS T                  •V$ROLLNAME T/P       •V$PX_SESSION P
• V$WAITSTAT T/P               •V$ROLLSTAT T/P       •V$SESSION_OBJECT_CACHE P
• V$SYSTEM_EVENT T/P           •V$WAITSTAT T/P
                               •V$LATCH T/P   T: Troubleshooting
                             P: Performance   T/P:Troubleshooting /Performance
     Collecting System Wide
            Statistics
 V$SYSSTAT
 • Statistic number           V$SGASTAT
 • Name               About   • Pool
 • Class              290     • Name
 • Value                      • Bytes
V$EVENT_NAME             V$SYSTEM_EVENT
• Event number           • Event
• Name                   • Total waits
• Parameter 1            • Total timeouts
• Parameter 2            • Time waited
• Parameter 3            • Average wait
 Dictionary and Special Views
The following dictionary and special views
   provide useful statistics after using the
   DBMS_STATS package:
• DBA_TABLES, DBA_TAB_COLUMNS
• DBA_CLUSTERS
• DBA_INDEXES, INDEX_STATS
• INDEX_HISTOGRAM,
   DBA_TAB_HISTOGRAMS
This statistical information is static until you
   re execute DBMS_STATS.
     Collecting Session-Related
              Statistics
                                          V$SESSION
V$STATNAME           V$SESSTAT
                                          • SID
• Statistic number   • SID
                                          • Serial number
                     • Statistic number
• Name                                    • Username
                     • Value
• Class                                   • Os user
                                          V$SESSION_WAIT
V$SESSION_EVENT        V$EVENT_NAME       • SID
• SID                  • Event number     • Sequence number
• Event                • Name             • Event
• Total waits          • Parameter 1      • Parameter 1/2/3 text
• Total timeouts       • Parameter 2      • Wait time
• Time waited          • Parameter 3      • Seconds in wait
• Average wait                            • State
• Maximum wait
        Oracle Wait Events
• A collection of wait events provides
   information on the sessions that had to wait
   or must wait for different reasons.
• These events are listed in the
   V$EVENT_NAME view, which has the
   following columns:
  – EVENT#
  – NAME
  – PARAMETER1
  – PARAMETER2
  – PARAMETER3
  About 290 wait events are there in Oracle Server.
 The V$EVENT_NAME View
  SQL> SELECT name, parameter1, parameter2,
    parameter3 FROM v$event_name;
The V$SYSTEM_EVENT View
SQL> SELECT event, total_waits,
total_timeouts,time_waited, average_wait FROM
v$system_event;
 The V$SESSION_EVENT View
 SQL> select sid, event, total_waits, average_wait
 from v$session_event where sid=10;
The V$SESSION_WAIT View
SQL> SELECT sid, seq#, event, wait_time, state FROM
v$session_wait;
                  STATSPACK
• Installation of STATSPACK
   – $ORACLE_HOME/rdbms/admin/spcreate.sql
• Collection of statistics
   – execute STATSPACK.snapas perfstat
• Automatic collection of statistics
   – $ORACLE_HOME/rdbms/admin/spauto.sql use
     dbms_jobs method for collecting statitics.
• Produce a report
   – $ORACLE_HOME/rdbms/admin/spreport.sql
• To collect timing information, set
TIMED_STATISTICS = true
      STATSPACK Output
Information found on the first page:
• Database and instance name
• Time at which the snapshots were taken
• Current sizes of the caches
• Load profile
• Efficiency percentages of the instance
• Top five wait events
         STATSPACK Output
Information found in the remainder of the document:
• Complete list of wait events
• Information on SQL statements currently in the pool
• Instance activity statistics
• Tablespace and file I/O
• Buffer pool statistics
• Rollback or undo segment statistics
• Latch activity
• Dictionary cache statistics
• Library cache statistics
• SGA statistics
• Startup values for init.ora parameters
      Other Utilities and Tools
• Utlbstat.sql and utlestat.sql can be used to
  provide information from the beginning of
  the instance to the end.
• Enterprise Manager –Performance Manager
• Oracle Expert tuning
• Use DBA-Developed Tools for collecting
  statistics.
   UTLBSTAT and UTLESTAT
          Utilities
These utilities:
• Gather performance figures over a defined period
• Produce a hard-copy report
• To fully use these, set TIMED_STATISTICS to
   TRUE
• Use the utlbstat.sql and utlestat.sql scripts
• Run the scripts from SQL*Plus connected as
SYSDBA
• STATSPACK provides clearer statistics.
 Dictionary and Special Views
The following dictionary and special views
   provide useful statistics after using the
   DBMS_STATS package:
• DBA_TABLES, DBA_TAB_COLUMNS
• DBA_CLUSTERS
• DBA_INDEXES, INDEX_STATS
• INDEX_HISTOGRAM,
   DBA_TAB_HISTOGRAMS
This statistical information is static until you
   re execute DBMS_STATS.
     Collecting Session-Related
              Statistics
                                          V$SESSION
V$STATNAME           V$SESSTAT
                                          • SID
• Statistic number   • SID
                                          • Serial number
                     • Statistic number
• Name                                    • Username
                     • Value
• Class                                   • Os user
                                          V$SESSION_WAIT
V$SESSION_EVENT        V$EVENT_NAME       • SID
• SID                  • Event number     • Sequence number
• Event                • Name             • Event
• Total waits          • Parameter 1      • Parameter 1/2/3 text
• Total timeouts       • Parameter 2      • Wait time
• Time waited          • Parameter 3      • Seconds in wait
• Average wait                            • State
• Maximum wait
        Oracle Wait Events
• A collection of wait events provides
   information on the sessions that had to wait
   or must wait for different reasons.
• These events are listed in the
   V$EVENT_NAME view, which has the
   following columns:
  – EVENT#
  – NAME
  – PARAMETER1
  – PARAMETER2
  – PARAMETER3
  About 290 wait events are there in Oracle Server.
 The V$EVENT_NAME View
  SQL> SELECT name, parameter1, parameter2,
    parameter3 FROM v$event_name;
The V$SYSTEM_EVENT View
SQL> SELECT event, total_waits,
total_timeouts,time_waited, average_wait FROM
v$system_event;
 The V$SESSION_EVENT View
 SQL> select sid, event, total_waits, average_wait
 from v$session_event where sid=10;
The V$SESSION_WAIT View
SQL> SELECT sid, seq#, event, wait_time, state FROM
v$session_wait;
                  STATSPACK
• Installation of STATSPACK
   – $ORACLE_HOME/rdbms/admin/spcreate.sql
• Collection of statistics
   – execute STATSPACK.snapas perfstat
• Automatic collection of statistics
   – $ORACLE_HOME/rdbms/admin/spauto.sql use
     dbms_jobs method for collecting statitics.
• Produce a report
   – $ORACLE_HOME/rdbms/admin/spreport.sql
• To collect timing information, set
TIMED_STATISTICS = true
      STATSPACK Output
Information found on the first page:
• Database and instance name
• Time at which the snapshots were taken
• Current sizes of the caches
• Load profile
• Efficiency percentages of the instance
• Top five wait events
         STATSPACK Output
Information found in the remainder of the document:
• Complete list of wait events
• Information on SQL statements currently in the pool
• Instance activity statistics
• Tablespace and file I/O
• Buffer pool statistics
• Rollback or undo segment statistics
• Latch activity
• Dictionary cache statistics
• Library cache statistics
• SGA statistics
• Startup values for init.ora parameters
      Other Utilities and Tools
• Utlbstat.sql and utlestat.sql can be used to
  provide information from the beginning of
  the instance to the end.
• Enterprise Manager –Performance Manager
• Oracle Expert tuning
• Use DBA-Developed Tools for collecting
  statistics.
   UTLBSTAT and UTLESTAT
          Utilities
These utilities:
• Gather performance figures over a defined period
• Produce a hard-copy report
• To fully use these, set TIMED_STATISTICS to
   TRUE
• Use the utlbstat.sql and utlestat.sql scripts
• Run the scripts from SQL*Plus connected as
SYSDBA
• STATSPACK provides clearer statistics.
      Managing Statistics
• Use the DBMS_STATS package:
  – GATHER_TABLE_STATS
  – GATHER_INDEX_STATS
  – GATHER_SCHEMA_STATS
  – GATHER_DATABASE_STATS
  – GATHER_STALE_STATS
   Gathering System Statistics
• System statistics enable the CBO to use CPU and I/O
   characteristics.
• System statistics must be gathered on a regular
basis; this does not invalidate cached plans.
• Gathering system statistics equals analyzing
system activity for a specified period of time.
• New procedures:
  – DBMS_STATS.GATHER_SYSTEM_STATS
  – DBMS_STATS.SET_SYSTEM_STATS
  – DBMS_STATS.GET_SYSTEM_STATS
      Managing Statistics
• Use the DBMS_STATS package:
  – GATHER_TABLE_STATS
  – GATHER_INDEX_STATS
  – GATHER_SCHEMA_STATS
  – GATHER_DATABASE_STATS
  – GATHER_STALE_STATS
   Setting the Optimizer Mode
• At the instance level:
   – optimizer_mode =
   {choose|rule|first_rows|first_rows_n|
   all_rows}
• At the session level:
   – alter session set optimizer_mode =
   {choose|rule|first_rows|first_rows_n|
   all_rows}
• At the statement level:
   – Using hints.
   Select /*+first_rows*/ from hr.emp;
      Optimizer Plan Stability
• Users can stabilize execution plans, in order to
force applications to use a desired SQL access
path.
• A consistent execution path is thereby maintained
   through database changes.
• This is done by creating a stored outline consisting
   of hints.
• The OPTIMIZER_FEATURES_ENABLE
   parameter enables the optimizer to keep CBO
   features of previous versions.
              Plan Equivalence
• SQL statement text must match the text in a
stored outline.
• Plans are maintained through:
   – New Oracle versions
   – New statistics on objects
   – Initialization parameter changes
   – Database reorganization
   – Schema changes.
• Users can stabilize execution plans and force
  applications to use a desired SQL access path by using
  stored outlines.
      Using Stored Outlines
• Set the USE_STORED_OUTLINES parameter
   to TRUE or to a category name:
SQL> alter session set
   USE_STORED_OUTLINES = train;
SQL> select … from … ;
• Both CREATE_STORED_OUTLINES and
USE_STORED_OUTLINES can be set at the
   instance or session level.
        Using Private Outlines
Private outlines are:
• Edited without affecting the running system
• Copies of current storage outlines
• Controlled using the
  USE_PRIVATE_OUTLINES parameter
      Editing Stored Outlines
Editing and using private outlines:
• Create the outline tables in the current schema
• Copy the selected outline to private outline
• Edit the outline stored as a private outline
• To use the private outline, set the
USE_PRIVATE_OUTLINE parameter
• To allow public access to the new stored outline,
overwrite the stored outline
• Reset USE_PRIVATE_OUTLINE to FALSE
  Maintaining Stored Outlines
• Use the OUTLN_PKG package to:
  – Drop outlines or categories of outlines
  – Rename categories
• Use the ALTER OUTLINE command to:
  – Rename an outline
  – Rebuild an outline
  – Change the category of an outline
• Outlines are stored in the OUTLN schema.
•Use hints in sql statements by /*+statement */
 Overview of Diagnostic Tools
• STATSPACK
• EXPLAIN PLAN
• SQL trace and TKPROF
• SQL*Plus autotrace feature
• Oracle SQL Analyze
• Explain plan an be used without tracing.
• These statistics are used by cost based
  optimizers.
• Statistics should be gathered only if we have
  enough data dictionary storage space.
             EXPLAIN PLAN
• Can be used without tracing
• Needs the PLAN_TABLE table utlxplan.sql
• Create the explain plan:
   SQL> Explain plan for select last_name from
    hr.employees;
• Query plan_table to display the execution plans:
   – Query PLAN_TABLE directly
   – Use script utlxpls.sql (Hide Parallel Query information)
   – Use script utlxplp.sql (Show parallel Query
   information)
      Managing Statistics
• Use the DBMS_STATS package:
  – GATHER_TABLE_STATS
  – GATHER_INDEX_STATS
  – GATHER_SCHEMA_STATS
  – GATHER_DATABASE_STATS
  – GATHER_STALE_STATS
          Table Statistics
• Number of rows
• Number of blocks and empty blocks
• Average available free space
• Number of chained or migrated rows
• Average row length
• Last ANALYZE date and sample size
• Data dictionary view: DBA_TABLES
           Index Statistics
• Index level (height)
• Number of leaf blocks and distinct keys
• Average number of leaf blocks per key
• Average number of data blocks per key
• Number of index entries
• Clustering factor
• Data dictionary view: DBA_INDEXES