Database Tuning: Definition - What Does Workload Mean?
Database Tuning: Definition - What Does Workload Mean?
Database Tuning: Definition - What Does Workload Mean?
The amount of work performed by an entity in a given period of time, or the average amount of work
handled by an entity at a particular instant of time. The amount of work handled by an entity gives an
estimate of the efficiency and performance of that entity. In computer science, this term refers to
computer systems' ability to handle and process work. Components such as servers or database systems
are often assigned an expected workload upon creation. Analysis of their performance compared to the
workload that was expected is then conducted over time.
One approach to boosting workload capabilities is to increase the number of servers and run
applications on different servers. The disadvantage of this approach is increased costs in setup,
maintenance and deployment. A few specific types of workload that apply to computer systems
include: Memory Workload Each program or instruction needs some memory to store temporary
or permanent data and perform intermediate computations. The memory workload determines
the memory use of the entire system over a given period of time or at a specific instant in time.
Paging and segmentation activities use a lot of virtual memory, thereby increasing the use of
main memory. However, when the number of programs being executed becomes so large that
memory becomes a bottleneck for performance, it indicates more memory is needed or programs
need to be managed in a more effective manner. CPU Workload CPU workload indicates the
number of instructions being executed by the processor during a given period or at a particular
instant of time. This statistic indicates a need for an increase in processing power if the CPU is
overloaded all the time, or a decrease in processing power if CPU use falls below a certain
threshold. Further performance improvements can be obtained for the same number of
instructions executing on a CPU at a given instant of time by decreasing the number of cycles
required by an instruction for successful execution. The latter can be achieved by improving code
efficiency. I/O Workload Most applications tend to spend considerable time gathering input and
producing output. As a result, the workload of input-output (I/O) combinations on a system must
be analyzed thoroughly to ensure that appropriate load performance parameters are met. A
statistic on the number of inputs gathered by a system and the number of outputs produced by a
system over a particular duration of time is termed as input-output workload. Database
Workload Databases can be analyzed for their memory use, throughput at maximum loads and
I/O throughput. Each of these components can give a small approximation of the database
performance and its parameters. However, the true workload of a database can be analyzed by
determining the number of queries executed by the database in a given period of time, or the
average number of queries being executed at a particular instant of time.
Database tuning
From Wikipedia, the free encyclopedia
This article needs additional citations for verification. Please help improve this article by
adding citations to reliable sources. Unsourced material may be challenged and removed.
(December 2008) (Learn how and when to remove this template message)
Database tuning describes a group of activities used to optimize and homogenize the performance of a
database. It usually overlaps with query tuning, but refers to design of the database files, selection of
the database management system (DBMS) application, and configuration of the database's environment
(operating system, CPU, etc.).
Database tuning aims to maximize use of system resources to perform work as efficiently and rapidly
as possible. Most systems are designed to manage their use of system resources, but there is still much
room to improve their efficiency by customizing their settings and configuration for the database and
the DBMS.
Contents
1 I/O tuning
2 DBMS tuning
2.1 DBMS users and DBA experts
2.2 Automatic DB tuning
3 Database maintenance
4 References
I/O tuning
Hardware and software configuration of disk subsystems are examined: RAID levels and configuration,
[1] block and stripe size allocation, and the configuration of disks, controller cards, storage cabinets,
and external storage systems such as SANs. Transaction logs and temporary spaces are heavy
consumers of I/O, and affect performance for all users of the database. Placing them appropriately is
crucial.
Frequently joined tables and indexes are placed so that as they are requested from file storage, they can
be retrieved in parallel from separate disks simultaneously. Frequently accessed tables and indexes are
placed on separate disks to balance I/O and prevent read queuing.
DBMS tuning
DBMS users and DBA experts
DBMS tuning refers to tuning of the DBMS and the configuration of the memory and processing
resources of the computer running the DBMS. This is typically done through configuring the DBMS,
but the resources involved are shared with the host system.
Tuning the DBMS can involve setting the recovery interval (time needed to restore the state of data to a
particular point in time), assigning parallelism (the breaking up of work from a single query into tasks
assigned to different processing resources), and network protocols used to communicate with database
consumers.
Memory is allocated for data, execution plans, procedure cache, and work space[clarify]. It is much
faster to access data in memory than data on storage, so maintaining a sizable cache of data makes
activities perform faster. The same consideration is given to work space. Caching execution plans and
procedures means that they are reused instead of recompiled when needed. It is important to take as
much memory as possible, while leaving enough for other processes and the OS to use without
excessive paging of memory to storage.
Processing resources are sometimes assigned to specific activities to improve concurrency. On a server
with eight processors, six could be reserved for the DBMS to maximize available processing resources
for the database.
Automatic DB tuning
Utilizes machine learning to learn to evaluate performance under various workloads.[2][3][4]
Database maintenance
Database maintenance includes backups, column statistics updates, and defragmentation of data inside
the database files.[5]
On a heavily used database, the transaction log grows rapidly. Transaction log entries must be removed
from the log to make room for future entries. Frequent transaction log backups are smaller, so they
interrupt database activity for shorter periods of time.
DBMS use statistic histograms to find data in a range against a table or index. Statistics updates should
be scheduled frequently and sample as much of the underlying data as possible. Accurate and updated
statistics allow query engines to make good decisions about execution plans, as well as efficiently
locate data.
Defragmentation of table and index data increases efficiency in accessing data. The amount of
fragmentation depends on the nature of the data, how it is changed over time, and the amount of free
space in database pages to accept inserts of data without creating additional pages.
Tuning Overview
In this section, you will cover the following topics related to tuning overview:
Discussing the nature of tuning
Outlining a tuning methodology
Identifying diagnostic tools
The Oracle database server is designed to meet the needs of different applications, including those
applications that have large user populations who execute many transactions to put data into the
database and modify existing data in that database. Oracle also serves the needs of organizations that
require large amounts of data to be available in a data warehouse, or an application that contains vast
amounts of data available primarily for read access and reporting. In order to meet the needs of these
different types of applications, Oracle offers a great deal of flexibility in the way it can be configured.
The ongoing tuning process is used by DBAs to run the Oracle Server in such a way as to maximize
query performance, storage management, and resource usage according to the needs of the application.
This section will begin the discussion of the nature of tuning, allowing you to make the most of Oracle.
are caused by the applicationnot the Oracle database. Poorly written SQL statements, the use of
multiple SQL statements where one would suffice, and other problems within an application are the
source of most performance issues. The DBA should always place the responsibility of the first step in
any performance situation onto the application developers to see if they can rewrite the code of the
application to utilize the database more effectively.
Only after all possibility for resolving the performance issue by redeveloping the application is
exhausted should the DBA attempt any changes to the configuration of the Oracle database. This
consideration is designed to prevent the impromptu reconfiguration of the Oracle database to satisfy a
performance need in one area, only to create a performance problem in another area. Any change to the
configuration of the Oracle database should be considered carefully. The DBA should weigh the tradeoffs she might need to make in order to improve performance in one area. For example, when changing
the memory management configuration for the Oracle database without buying and installing more
memory, the DBA must be careful not to size any part of the Oracle SGA out of real memory. Also, if
the Oracle SGA takes up more existing memory, other applications that might be running on the same
machine may suffer. The DBA may need to work in conjunction with the systems administrator of the
machine to decide how to make the trade-off.
Exercises
1. Why must a database be tuned?
2. What is the cause of most performance problems on Oracle databases?
Exercises
1. What are the three general categories of performance goals?
2. Where are the four steps for performance tuning? In what order should the DBA engage in these
from PLAN_TABLE using a special query provided by Oraclethis query will display the information
in PLAN_TABLE in a certain way that requires interpretation of the innermost indented operation
outward, and then from top to bottom. More information about using explain plan will be presented in
Chapter 17.
ENTERPRISE MANAGER PERFORMANCE PACK
This set of utilities contains products that will help the DBA identify performance issues. This package
is available mainly to organizations using Oracle on servers running Windows operating systems. This
option may not be as well known to DBAs in organizations using Oracle in UNIX environments,
because many DBAs use Oracle database management tools in line mode.
SQL TRACE
This tool extends the functionality provided by explain plan by giving statistical information about the
SQL statements executed in a session that has tracing enabled. This additional statistical information is
provided in a dump file. This utility is run for an entire session using the alter session set sql_trace =
true statement. Tracing a session is especially useful for analyzing the full operation of an application
or batch process containing multiple transactions, where it is unclear which part of the application or
batch process is encountering performance issues.
TKPROF
The dump file provided by SQL Trace is often hard to read. TKPROF takes the output in a trace file
and turns it into a more understandable report. The relationship between SQL TRACE and TKPROF is
similar to the relationship between IMPORT and EXPORT, as TKPROF only operates or accepts as
input the output file produced by SQL TRACE. The contents of the report produced by TKPROF will
be discussed.
V$ VIEWS
These are views against several memory structures created by the Oracle SGA at instance startup.
These views contain database performance information that is useful to both DBAs and Oracle to
determine the current status of the database. The operation of performance tuning tools, such as those
in the Oracle Enterprise Manager or Server Manager utilities running in GUI mode as well as utilities
available from third-party vendors, use the underlying V$ performance views as their basis for
information.
Exercises
1. Identify the usage of the UTLBSTAT and the UTLESTAT tools. Which tool produces
report.txt?
2. Identify the tool that identifies the execution plan of a given SQL query. In what step of
Oracles recommended tuning methodology might this information be useful?
3. What are the V$ views, and how are they used in the database?
Diagnosing Problems
In this section, you will cover the following topics related to diagnosing problems:
V$SYSTEM_EVENT
V$SYSSTAT
V$ROLLSTAT
V$ROWCACHE
V$LATCH
V$SESSION
V$LIBRARYCACHE
V$SESSION_EVENT
TIP: In order to execute UTLBSTAT, the TIMED_STATISTICS parameter must be set to TRUE for the Oracle
instance in the init.ora file. Certain information will not be captured by the utility if this parameter is not
correctly set. Also, do not run this utility against a database that has not been running for several hours
or more, as it relies on dynamic performance views that will not contain useful information if the
database has not been running for some time.
UTLESTAT ends the collection of performance statistics from the views named above. Typically, the
script is found in the same location as UTLBSTAT, in the rdbms/admin directory under the Oracle
software home directory, and it is executed from Server Manager. Though it is not necessary to execute
the connect internal command before executing this query, the DBA should connect to the database as
a user with connect internal privileges prior to running the query. This utility will gather all statistics
collected and use them to generate an output file called report.txt. After generating report.txt, the
utility will remove the statistics tables it used to store the performance history of the database. The
contents of report.txt will be discussed shortly.
Care should be taken not to shut down the database while UTLBSTAT is running. If this should
happen, there could be problems with interpreting the data, and since the database must be running for
several hours in order for the V$ views that UTLBSTAT depends on to contain useful data, all work
done by UTLBSTAT will be useless. The best thing to do in this situation is to run UTLESTAT as soon
as possible to clear out all data from the prior run, and wait until the database has been up long enough
to attempt a second execution.
Exercises
1. What is the purpose of the UTLBSTAT utility? What database initialization parameter should be
set to TRUE before UTLBSTAT is executed?
2. What is the purpose of the UTLESTAT utility? What is the name of the output file produced by
this utility?
BODY21210
0
CLUSTER01010
0
INDEX01010
0
OBJECT01010
0
PIPE01010
0
SQLAREA5098.60518740.772185
0
TABLE/PROCED7762.98915138.982186
0
TRIGGER01010
0
SVRMGR>RemThetotalisthetotalvalueofthestatisticbetweenthe
time
SVRMGR>Rembstatwasrunandthetimeestatwasrun.Notethatthe
estat
SVRMGR>Remscriptlogsonas"internal"sotheper_logonstatistics
will
SVRMGR>Remalwaysbebasedonatleastonelogon.
SVRMGR>selectn1.name"Statistic",n1.change"Total",
2>round(n1.change/trans.change,2)"PerTransaction",
3>round(n1.change/logs.change,2)"PerLogon"
4>fromstats$statsn1,stats$statstrans,stats$statslogs
5>wheretrans.name='usercommits'
6>andlogs.name='logons'andn1.change!=0
7>orderbyn1.name;
0rowsselected.
SVRMGR>RemAveragelengthofthedirtybufferwritequeue.Ifthis
islargerthan
SVRMGR>Remthevalueofthedb_block_write_batchinit.oraparameter,
consider
SVRMGR>Remincreasingthevalueofdb_block_write_batchandcheck
fordisksthat
SVRMGR>RemaredoingmanymoreIOsthanotherdisks.
SVRMGR>selectqueue.change/writes.change"AverageWriteQueue
Length"
2>fromstats$statsqueue,stats$statswrites
3>wherequeue.name='summedwritequeuelength'
4>andwrites.name='writerequests';
0rowsselected.
SVRMGR>RemI/Oshouldbespreadevenlyacrossdrives.Abig
differencebetween
SVRMGR>Remphys_readsandphys_blks_rdimpliestablescansaregoing
on.
SVRMGR>select*fromstats$filesorderbytable_space,file_name;
TABLE_SPACE FILE_NAMEPHYS_READSPHYS_BLKS_RDPHYS_RD_TIMEPHYS_WRITESPHYS_BLKS_WRPHYS_WRT_TIM
DATA/u01/oradata/norm/data01.dbf30340501081080
INDEX/u03/oradata/norm/index01.dbf200189056560
RBS/u04/oradata/norm/rbs01.dbf7702022020
SYSTEM/u02/oradata/norm/system01.dbf1072373103673670
TEMP/u05/oradata/norm/temp01.dbf33402802800
USERS/u05/oradata/norm/users01.dbf000000
SVRMGR>Remsumovertablespaces
SVRMGR>selecttable_space,sum(phys_reads)phys_reads,
2>sum(phys_blks_rd)phys_blks_rd,
3>sum(phys_rd_time)phys_rd_time,sum(phys_writes)phys_writes,
4>sum(phys_blks_wr)phys_blks_wr,sum(phys_wrt_tim)phys_wrt
5>fromstats$filesgroupbytable_spaceorderbytable_space;
PHYS_READSPHYS_BLKS_RDPHYS_RD_TIMEPHYS_WRITESPHYS_BLKS_WRPHYS_WRT
DATA3034050108108
0
INDEX20018905656
0
RBS770202202
0
SYSTEM107237310367367
0
TEMP3340280280
0
TOOLS11000
0
USERS00000
0
TBLE_SPACE
SVRMGR>RemSleepsshouldbelow.Thehit_ratioshouldbehigh.
SVRMGR>selectnamelatch_name,gets,misses,
2>round(decode(getsmisses,0,1,getsmisses)/decode(gets,0,1,gets),3)
3>hit_ratio,sleeps,round(sleeps/decode(misses,0,1,misses),3)
"SLEEPS/MISS"
4>fromstats$latcheswheregets!=0orderbyname;
LATCH_NAMEGETSMISSESHIT_RATIOSLEEPS
SLEEPS/MISS
cachebufferhandl532010
0
cachebufferschai11935402031514
2.532
cachebufferslru20200145.993332
2.29
dmllockallocatio1016010
0
enqueues3601010
0
librarycache133513853.9941887
2.212
messages1998010
0
multiblockreadob5265010
0
processallocation14010
0
redoallocation37764.99915
3.75
rowcacheobjects150451266.998633
2.38
sequencecache170010
0
sessionallocation14301.9991
1
sessionidlebit372047111
1.571
sharedpool87978447.995931
2.083
systemcommitnumb77024.9999
2.25
transactionalloca578010
0
undoglobaldata442010
0
userlock30010
0
SVRMGR>RemStatisticsonno_waitlatchgets.No_waitgetdoesnot
waitforthe
SVRMGR>Remlatchtobecomefree,itimmediatelytimesout.
SVRMGR>selectnamelatch_name,
2>immed_getsnowait_gets,
3>immed_missnowait_misses,
4>round(decode(immed_getsimmed_miss,0,1,immed_getsimmed_miss)/
5>decode(immed_gets,0,1,immed_gets),3)nowait_hit_ratio
6>fromstats$latcheswhereimmed_gets!=0orderbyname;
LATCH_NAMENOWAIT_GETSNOWAIT_MISSES
NOWAIT_HIT_RATIO
cachebufferschai87850109.999
cachebufferslru58027718656.968
librarycache55545.919
rowcacheobjects64960.908
SVRMGR>RemWaits_for_trans_tblhighimpliesyoushouldaddrollback
segments.
SVRMGR>select*fromstats$roll;
UNDO_SEGTRANS_T_GTRANS_T_WUNDO_BYT_WRSEGMENT_SIZE_BYTXACTS
SHRINKSWRAPS
060018022400
0
2680109151064550400
0
328048571064550400
0
4650140271064550400
0
518017861064550400
0
610015301064550410
0
7580183061064550410
0
850080181064550410
0
9390130201064550400
0
106001064550400
0
116001064550400
0
12510125551064550400
0
13610101941064550400
0
1457010081106455041
00
15809381064550410
0
1629033691064550410
0
1720032671064550400
0
18680588611064550400
0
1912061871064550400
0
206001064550400
0
216001064550400
0
SVRMGR>RemTheinit.oraparameterscurrentlyineffect:
SVRMGR>selectname,valuefromv$parameterwhereisdefault='FALSE'
2>orderbyname;
NAMEVALUE
audit_trailNONE
background_dump_dest
$ORACLE_BASE/admin/norm/bdump
control_files
/u02/oradata/norm/control.ctl
core_dump_dest
$ORACLE_BASE/admin/norm/cdump
db_block_buffers6000
db_block_size4096
db_file_multiblock_read_count8
db_file_simultaneous_writes8
db_files200
db_namenorm
distributed_transactions61
dml_locks750
enqueue_resources5000
gc_db_locks6000
ifile
/u07/app/oracle/admin/norm/pfile/config
log_archive_dest
$ORACLE_BASE/admin/norm/arch/arch.log
log_archive_format'log%S%T.arch'
log_checkpoint_interval4096
log_checkpoints_to_alertTRUE
log_simultaneous_copies0
max_dump_file_size10240
max_enabled_roles22
mts_servers0
nls_sortBINARY
open_cursors255
optimizer_modeRULE
pre_page_sgaTRUE
processes200
resource_limitTRUE
rollback_segmentsr01,r02,r03,r04,r05
row_lockingALWAYS
sequence_cache_entries30
sequence_cache_hash_buckets23
sessions225
shared_pool_size31457280
sort_area_retained_size131072
sort_area_size131072
temporary_table_locks225
transactions206
transactions_per_rollback_segment42
user_dump_dest
$ORACLE_BASE/admin/norm/udump
SVRMGR>Remget_missandscan_missshouldbeverylowcomparedtothe
requests.
SVRMGR>Remcur_usageisthenumberofentriesinthecachethatare
beingused.
SVRMGR>select*fromstats$dc
2>whereget_reqs!=0orscan_reqs!=0ormod_reqs!=0;
NAMEGET_REQSGET_MISSSCAN_REQSCAN_MISMOD_REQSCOUNT
CUR_USAG
dc_tablespaces45000015
12
dc_free_extents130053640133
311302
dc_segments2789210051315
310
dc_rollback_seg264000024
23
dc_used_extents6540006562
54
dc_users134000036
24
dc_user_grants59000058
19
dc_objects7837109000984
983
dc_tables2163615000415
412
dc_columns62063227230015220
1110611100
dc_table_grants18080113000
956938
dc_indexes3620392742120849
848
dc_constraint_d554826190536
535
dc_constraint_d0041201
0
dc_synonyms252485000510
509
dc_usernames3010000044
40
dc_sequences1563002446
43
dc_sequence_gra984000124
123
dc_tablespaces380003816
8
dc_profiles1400008
1
SVRMGR>RemThetimesthatbstatandestatwererun.
SVRMGR>select*fromstats$dates;
STATS_GATHER_TIMES
28JUN9915:20:42
28JUN9916:30:40
An important facet of performance tuning lies in knowing how to set initialization parameters.
Knowing the values of these parameters often becomes an issue when trying to identify and solve
problems. Although the DBA can find the values of initialization parameters by reading the init.ora file
used to start the database instance, this method of determining initialization parameters for the instance
isnt the most accurate. Instead, the DBA should use the show parameter command available in Server
Manager. Alternately, the following select statement using the V$PARAMETER view will show the
initialization parameters for the instance:
SELECT name, value
FROM v$parameter;
The next four chapters on performance tuning that comprise this unit utilize information from dynamic
performance views on the Oracle database. These views are the cornerstone of statistics collection for
the Oracle database and are used by many performance monitoring tools such as Server Manager.
Access to these views, whose names generally start with either V$ or X$, is as follows: V$ views can
be accessed either by the DBA logging in as the owner (SYS) or as a user with the select any table
privilege granted to it. The X$ views can be accessed only by user SYS.
TIP: In Oracle7, V$ performance views are accessed by any user with select any table object privilege granted to
them. X$ views are accessed only by user SYS. However, the select any table object privilege doesnt have
to give access to V$ views in Oracle8--see Chapter 25 for details.
Exercises
1. The output for the report.txt file shows a great deal of hit and wait information. What do you
think this information means? What sorts of values (high or low) for hits and waits do you think
indicate good or poor database performance?
2. You are the DBA on a database experiencing performance problems accessing information from
many dictionary views. The database has been running for a while. You use the UTLBSTAT and
UTLESTAT utilities to pinpoint the cause of the performance degradation. In what area might
you look in the output file to see if there is a problem?
3. Name the sections of the report.txt file and identify uses for each.
on latches by latch number. This listing should give an idea about the types of latches that are available
in Oracle:
SELECT * FROM v$latchname;
LATCH# NAME
--------- ------------------------0
latch wait list
1
process allocation
2
session allocation
3
session switching
4
session idle bit
5
messages
6
enqueues
7
trace latch
8
cache buffers chains
9
cache buffers lru chain
10
cache buffer handle
11
multiblock read objects
12
cache protection latch
13
system commit number
14
archive control
15
redo allocation
16
redo copy
17
dml lock allocation
18
transaction allocation
19
undo global data
20
sequence cache
21
row cache objects
22
cost function
23
user lock
24
global transaction mapping table
25
global transaction
26
shared pool
27
library cache
29
virtual circuit buffers
30
virtual circuit queues
31
virtual circuits
32
NLS data objects
33
query server process
34
query server freelists
35
error message lists
36
process queue
37
process queue reference
38
parallel query stats
The latches in the list above manage many different resources on the Oracle database. Those resources,
along with some of the latches from above that handle management of that resource, are listed below:
Buffer cache Cache buffers chain, cache buffers LRU chain, cache buffer handle,
Obtaining Latches
To obtain any of the resources listed in the previous code block, the process must first acquire the latch.
Processes that request latches to perform activities using Oracle resources do not always obtain the
latch the first time they request them. There are two behaviors that processes will undertake when they
need to use a latch and find that the latch is not available for their use. One is that the process will wait
for the latch to become available for the processs use. The other is that the process will not wait for the
latch to become available, but instead will move on within its own process.
V$LATCHHOLDER handles identifying the processes running on the database that are holding
latches. These particular processes may be causing waits on the system. A query against
V$LATCHHOLDER will allow the user to identify the process IDs for all processes holding the latch.
Since the period of time that any process will hold a latch is very brief, the task of identifying waits on
the system, as discussed earlier, can be accomplished by continuously monitoring V$LATCHHOLDER
to see which users are holding latches excessively. If there are processes that are holding latches for a
long while, that process will appear again and again. Performance for all processes that are waiting for
the latch to be free will wait as well.
Unfortunately, each of these views uses a rather cryptic method of identifying which latch is currently
being held. A listing of the columns in each table and their meaning follows this discussion. One
solution to the problem of cryptic latch numbers used to identify the latch being used is to use
V$LATCHNAME. This view maps the latch number to a more readable name that the DBA can
associate with a latch. A sample query is given below that will list out the latches that are currently
being held by a process, as well as the name of the latch being held:
SELECT h.pid, n.name
FROM v$latchholder h, v$latchname n, v$latch l
WHERE h.laddr = l.addr
AND l.latch# = n.latch#;
H.PID N.NAME
--------- ----------------------34
redo allocation
12
library cache
Note that this query performs a join through the V$LATCH performance view. This is because the link
from the latch name in V$LATCHNAME and the latch address that is given in V$LATCHHOLDER
can only be made through the latch number, which is present in V$LATCH. More information about
the contents of each performance view designed to store latch statistics can be found in Figure 16-1.
Figure 1: V$ performance views storing latch statistics
Exercises
1. Identify several different latches in the database. What resource do the redo allocation and copy
latch handle resource management for?
2. What are two different ways a process may request access to a latch?
3. What are three dynamic performance views showing information about latches?
This new feature of the latch holder query adds in the ratio of times a process did not obtain the latch
vs. the total number of times the latch was requested. Consistent monitoring of these V$ performance
views yields the following: If the same process shows up time and time again as holding the latch
named, and the wait ratio is high for that latch, then there could be a problem with an event causing a
wait on the system.
To find out more about the events or processes that are suffering as a result of an event causing waits,
the V$PROCESS view can be put into play. V$PROCESS has a special column associated with it that
identifies the address of a latch for which that process is currently experiencing a wait. This column is
usually NULL, but if there is a value present for it then there is a wait happening. Associating the latch
name and wait ratio can be accomplished with an extension of the query already identified. The
following code block demonstrates this:
SELECT p.pid, n.name, (l.misses/l.gets)*100 wait_ratio
FROM v$process p, v$latchname n, v$latch l
WHERE p.latchwait is not null
AND p.latchwait = l.addr
AND l.latch# = n.latch#;
P.PID N.NAME
WAIT_RATIO
------- ---------------- ------------34
redo allocation 1.0304495
The execution of this query produces the process identifier for a process experiencing the wait, the
name of the latch that is currently held by another process, and the wait ratio for that latch overall. The
functionality that these V$ views give can be better managed with use of the MONITOR LATCH menu
item present in Oracles utilities for database administration, Server Manager. This feature is not
available in Oracle8.
There are two types of requests for latches. The distinction between each type of request is based on
whether the requestor will continue to run if the latch is not available to that process. Some processes
are willing to wait for the latch, while others are not. If a process will wait for the latch, the following
series of events will take place:
1. The process will request the latch.
2. If the latch is available, the process will obtain it.
3. If the latch is unavailable, the process will wait a short period of time and ask for the latch
again. This period of wait time is called a sleep. The process will continue its cycle of asking
and sleeping until the latch becomes available.
Unlike those processes that are willing to wait until a latch becomes available, there are other processes
that will not wait until the latch is free to continue. These processes require the latch immediately or
they move on. The V$LATCH dynamic performance view captures statistics on both types of latch
requests. The following chart depicts the columns of V$LATCH, the explanation of the column, and the
corresponding type of request it reflects:
Willing to wait
MISSES
Willing to wait
SLEEPS
Willing to wait
IMMEDIATE_GETS
Immediate
IMMEDIATE_MISSES
Immediate
GETS
Consider a couple of examples of obtaining latches to understand the process Oracle uses to maintain
latch statistics better. Assume a user process puts forth an immediate request to obtain a latch. The latch
is available, so the request is granted and the user process obtains the latch. The IMMEDIATE_GETS
column on V$LATCH corresponding to the row entry for that latch will be incremented by one . Using
that same example, lets say now that the latch was busy. Instead, Oracle will now update the
IMMEDIATE_MISSES column on the corresponding row entry in V$LATCH for that latch. This
example illustrates that the statistics compilation process for immediate requests for latches is
straightforward.
Now, let us consider the more involved process of compiling statistics for willing to wait requests. A
user process makes a willing to wait request for a latch. The latch is available, so the process obtains
the latch. The GETS column from V$LATCH is incremented by one . Using the same example, the
user process requests a latch, but this time the latch is unavailable. The user process has to wait. So, the
user process goes to sleep. The MISSES column is incremented and the SLEEP column is incremented,
and the process doesnt get its latch. After a short period, the process wakes up and asks for the process
again. The latch is now available, so the GETS column in V$LATCH for that latch is incremented as
well. One can see that the numbers will add up on those columns corresponding to willing to wait
requests if latches become tough to obtain.
The next important aspect of latches to cover is calculation of the wait ratio for a latch. The DBA can
obtain the wait ratio for a given latch by executing the following query against Oracle:
SELECT n.name,
(l.misses/l.gets)*100 w2wait_ratio,
(l.immediate_misses/l.immediate_gets)*100 immed_ratio,
FROM v$latch l, v$latchname n
WHERE n.name in (redo copy,redo allocation)
AND n.latch# = l.latch#;
N.NAME
W2WAIT_RATIO IMMED_RATIO
----------------- -------------- -------------redo allocation 1.0304495
2.9405949
Any of the names for latches listed in the code block displaying the contents of V$LATCHNAME can
be used as part of the in clause in this statement. However, as we will learn in this unit, the latches that
manage access to the redo log resources are particularly important because there are few of them, and
every process that makes changes to data needs access to them. If either the wait ratio on willing to
wait or the immediate latch requests for the latch named by the DBA in the query are greater than 1,
then there is a problem with latch contention in the database.
Exercises
1. What is a willing to wait request for a latch? How does it differ from an immediate request for a
latch?
2. What is a wait ratio? What are the two types of wait ratios associated with latches? How can the
DBA find out what the wait ratio is? If the wait ratio is 6, is there an issue with latch contention
in the database?
Chapter Summary
In this chapter we have covered the fundamentals in this advanced area of performance tuning as
evaluated by OCP Exam 4. These areas are the tuning overview and problem diagnostics. These two
topics comprise 15 percent of OCP Exam 4 content. The beginning of this chapter focused on the
nature of database tuning. The text outlined three goals for any DBA approaching the task of
performance tuning. They are improving performance of certain queries running against the Oracle
database, improving performance of certain applications running against Oracle, and improving
Oracles overall handling of database user and application load. The text also covered why DBAs
should always begin the tuning process by trying to achieve the first goal, that of tuning the SQL
queries first. Only when that approach does not work should higher levels of performance tuning be
sought.
The following steps were also presented as the outline of an appropriate tuning methodology for DBAs.
Step 1 is to tune the applications. Step 2 is to tune memory structures. Step 3 is to tune disk I/O usage.
Step 4 is to detect and eliminate I/O contention. These steps are the Oracle-recommended outline of
tasks to execute in all tuning situations. The DBA is encouraged to use these steps when he or she isnt
sure of the cause for poor performance on the Oracle database. Following the logical hierarchy or scope
of each change is the important feature to remember from this section. OCP Exam 4 will focus some
attention on taking the most appropriate tuning measure without making sweeping changes to the
database in order to avoid causing more problems than were solved.
The tools used to diagnose and solve performance issues were also discussed in this chapter. One
important method the DBA will use to determine performance issues on an Oracle database involves
the use of the statistics gathering utilities UTLBSTAT and UTLESTAT. The location of these utilities
on the Oracle distribution is usually the rdbms/admin subdirectory under the Oracle software home
directory. UTLBSTAT begins statistics collection for observing database performance over an extended
period of time. When executed, this process will create the necessary data dictionary tables to store
performance data history, and then it will begin collecting those historical performance statistics.
UTLESTAT is the statistics collection end utility. On execution, it takes the statistics gathered in the
tables UTLBSTAT created and creates a report based on that data. The report name is report.txt, and it
can be found in the current directory. The report.txt file consists of several parts, which are described
and illustrated in the chapter body.
These tools are dependent on performance data collected by the V$ views in the Oracle data dictionary.
That data is valid only for the current Oracle instance; the data is not carried over when an instance is
shut down. Since it takes some time for those statistics gathered to have any meaning, it is wise to hold
off running UTLBSTAT and UTLESTAT until the database instance has been available for several
hours.
Also covered by this chapter was the topic of latch contention in the Oracle instance redo log. Similar
to locks, latches exist to limit access to certain types of resources. There are at least 40 different latches
in the Oracle database. Two important latches in the database manage the redo log resource. They are
the redo copy and redo allocation latch. Latches can be monitored by using the dynamic performance
views V$LATCH, V$LATCHHOLDER, and V$LATCHNAME. The statistics to monitor about latches
are the number of times a process has to wait for Oracle to fulfill a request it makes to obtain a latch vs.
the times a process requests a latch and obtains it. A process will generally do one of two things if it is
denied access to a latch. Its request is either immediate or willing to wait. These two types of process
requests affect the collection of V$LATCH statistics in the following way. V$LATCH tracks the
number of GETS, MISSES, and SLEEPS for processes willing to wait on a request for a latch. A
process will sleep if its latch request is denied and the process wants to wait for it to become available.
V$LATCH also calculates the number of IMMEDIATE_GETS and IMMEDIATE_MISSES for those
processes requesting latches that want the latch immediately or the process moves on. Latch wait time
for processes willing to wait is based on the number of MISSES divided by GETS, times 100, or
(MISSES/GETS)*100. Latch wait time for processes requiring immediate access to latches or the
process will move on is based on the number of IMMEDIATE_MISSES divided by
IMMEDIATE_GETS, times 100, or (IMMEDIATE_MISSES/IMMEDIATE_GETS) *100.
Looking for events causing waits was also covered. Events that are causing waits appear in both the
V$LOCK dynamic performance view and the V$LATCHHOLDER view. Both these views list
information about the processes that are currently holding the keys to access certain resources on the
Oracle database. If there are high wait ratios associated with a process holding a latch or lock, as
reflected by statistics gathered from V$LATCH or by the presence of a process ID in the V$LOCK
view, then there could be a contention issue on the database.
Two-Minute Drill
Three goals of performance tuning are improve performance of particular SQL
queries, improve performance of applications, and improve performance of the entire
database.
The four steps of performance tuning are as follows:
1. Tune applications
2. Tune memory structures
3. Tune I/O
4. Detect and resolve contention
Performance tuning steps listed above should be executed in the order given to avoid
making sweeping database changes that cause things to break in unanticipated ways.
The UTLBSTAT and UTLESTAT utilities are frequently used by DBAs to identify
performance issues on the Oracle database.
UTLBSTAT is the begin statistics collection utility. Executing this file creates special
tables for database performance statistics collection and begins the collection
process.
UTLESTAT is the end statistics collection utility. It concludes the statistics collection
activity started by UTLBSTAT and produces a report of database activity called
report.txt.
The report.txt file consists of the following components:
Statistics for file I/O by tablespace and datafile. This information is useful in
distributing files across many disks to reduce I/O contention.
SGA, shared pool, table/procedure, trigger, pipe, and other cache statistics. Used to
determine if there is contention for any of the listed resources.
Latch wait statistics for the database instance. Used to determine if there is
contention for resources using latches.
Statistics for how often user processes wait for rollback segments, which is used to
determine if more rollback segments should be added.
Average length of dirty buffer write queue, which is used to determine if DBWR is
having difficulty writing blocks to the database.
Initialization parameters for the database, including defaults.
Start time and stop time for statistics collection.
Latches are similar to locks in that they are used to control access to a database
resource. Latch contention is when two (or more) processes are attempting to acquire
a latch at the same time.
There are approximately 40 different types of latches in the Oracle database.
Latches are used in conjunction with restricting write access to online redo logs,
among other things. The two types of latches for this purpose are redo allocation
latches and redo copy latches.
Some processes make requests for latches that are willing to wait for the latch to be
free. Other processes move on if they cannot obtain immediate access to a latch.
V$LATCH is used for latch performance monitoring. It contains all GETS, MISSES,