You are on page 1of 34

1

Oracle Architectural Components

Copyright © Oracle Corporation, 2002. All rights reserved.


Objectives

After completing this lesson, you should be able to do


the following:
• Outline the Oracle architecture and its main
components
• List the structures involved in connecting a user to
an Oracle instance

1-2 Copyright © Oracle Corporation, 2002. All rights reserved.


Overview of Primary Components
Instance
User
process Shared Pool SGA

Library Redo Log


Database
Cache Buffer
Buffer Cache
Server Data Dictionary
process Cache Large Pool
Java Pool
PGA
PMON SMON DBWR LGWR CKPT Others

Data Control Redo Log


Parameter files files
files Archived
file Log files
Password
file
Database

1-3 Copyright © Oracle Corporation, 2002. All rights reserved.


Oracle Server

An Oracle server:
• Is a database management Oracle server

system that provides an open,


comprehensive, integrated
approach to information
management
• Consists of an Oracle
instance and an Oracle
database

1-5 Copyright © Oracle Corporation, 2002. All rights reserved.


Oracle Instance

An Oracle instance:
• Is a means to access an Oracle database
• Always opens one and only one database
• Consists of memory and background process
structures
Instance
Shared Pool SGA
Memory
Library Redo Log structures
Database
Cache Buffer
Buffer Cache
Data Dictionary
Cache Java Pool Large Pool
Background
PMON SMON DBWR LGWR CKPT Others process structures

1-6 Copyright © Oracle Corporation, 2002. All rights reserved.


Establishing a Connection
and Creating a Session

Connecting to an Oracle instance:


• Establishing a user connection
• Creating a session
Server
Connection process
established Session created
User Oracle server
process

Database user

1-7 Copyright © Oracle Corporation, 2002. All rights reserved.


Oracle Database

An Oracle database:
• Is a collection of data that is treated as a unit
• Consists of three file types

Oracle Database
Redo
Data Control Log
Parameter files files Archived
file files Log files
Password
file

1-9 Copyright © Oracle Corporation, 2002. All rights reserved.


Physical Structure

The physical structure includes three types of files:


• Control files
• Data files
• Online redo log files

Header
Control
Data files
files
Online (includes
Redo Log Data
files Dictionary)

1-10 Copyright © Oracle Corporation, 2002. All rights reserved.


Memory Structure

Oracle’s memory structure consists of two memory


areas known as:
• System Global Area (SGA): Allocated at instance
start up, and is a fundamental component of an
Oracle instance
• Program Global Area (PGA): Allocated when the
server process is started

1-11 Copyright © Oracle Corporation, 2002. All rights reserved.


System Global Area

• The SGA consists of several memory structures:


– Shared Pool
– Database Buffer Cache
– Redo Log Buffer
– Other structures (for example, lock and latch
management, statistical data)
• There are two additional memory structures that can
be configured within the SGA:
– Large Pool
– Java Pool

1-12 Copyright © Oracle Corporation, 2002. All rights reserved.


System Global Area

• Is dynamic
• Sized by the SGA_MAX_SIZE parameter
• Allocated and tracked in granules by SGA
components
– Contiguous virtual memory allocation
– Granule size based on total estimated SGA_MAX_SIZE

1-14 Copyright © Oracle Corporation, 2002. All rights reserved.


Shared Pool

• Used to store:
– Most recently executed SQL statements
– Most recently used data definitions
• It consists of two key performance-related memory
structures:
– Library Cache
– Data Dictionary Cache
Shared Pool
• Sized by the parameter Library
SHARED_POOL_SIZE Cache
Data
ALTER SYSTEM SET Dictionary
SHARED_POOL_SIZE = 64M; Cache

1-15 Copyright © Oracle Corporation, 2002. All rights reserved.


Library Cache

• Stores information about the most recently used


SQL and PL/SQL statements
• Enables the sharing of commonly used statements
• Is managed by a least recently used (LRU) algorithm
• Consists of two structures:
– Shared SQL area
– Shared PL/SQL area
• Size determined by the Shared Pool sizing

1-16 Copyright © Oracle Corporation, 2002. All rights reserved.


Data Dictionary Cache

• A collection of the most recently used definitions in


the database
• Includes information about database files, tables,
indexes, columns, users, privileges, and other
database objects
• During the parse phase, the server process looks at
the data dictionary for information to resolve object
names and validate access
• Caching data dictionary information into memory
improves response time on queries and DML
• Size determined by the Shared Pool sizing

1-17 Copyright © Oracle Corporation, 2002. All rights reserved.


Database Buffer Cache

• Stores copies of data blocks that have been


retrieved from the data files
• Enables great performance gains when you obtain
and update data
• Managed through an LRU algorithm
• DB_BLOCK_SIZE determines primary block size

Database Buffer
Cache

1-18 Copyright © Oracle Corporation, 2002. All rights reserved.


Database Buffer Cache

• Consists of independent subcaches:


– DB_CACHE_SIZE
– DB_KEEP_CACHE_SIZE
– DB_RECYCLE_CACHE_SIZE
• Can be dynamically resized
ALTER SYSTEM SET DB_CACHE_SIZE = 96M;

• DB_CACHE_ADVICE set to gather statistics for


predicting different cache size behavior
• Statistics displayed by V$DB_CACHE_ADVICE

1-19 Copyright © Oracle Corporation, 2002. All rights reserved.


Redo Log Buffer

• Records all changes made to the database data


blocks
• Primary purpose is recovery
• Changes recorded within are called redo entries
• Redo entries contain information to reconstruct or
redo changes
• Size defined by LOG_BUFFER

Redo Log
Buffer

1-21 Copyright © Oracle Corporation, 2002. All rights reserved.


Large Pool

• An optional area of memory in the SGA


• Relieves the burden placed on the Shared Pool
• Used for:
– Session memory (UGA) for the Shared Server
– I/O server processes
– Backup and restore operations or RMAN
– Parallel execution message buffers
PARALLEL_AUTOMATIC_TUNING set to TRUE
• Does not use an LRU list
• Sized by LARGE_POOL_SIZE
• Can be dynamically resized

1-22 Copyright © Oracle Corporation, 2002. All rights reserved.


Java Pool

• Services parsing requirements for Java commands


• Required if installing and using Java
• Sized by JAVA_POOL_SIZE parameter

1-24 Copyright © Oracle Corporation, 2002. All rights reserved.


Program Global Area

• Memory reserved for each user


process connecting to an Oracle PGA
database Server
process
• Allocated when a process is
created
• Deallocated when the process is User
terminated process
• Used by only one process

1-25 Copyright © Oracle Corporation, 2002. All rights reserved.


Process Structure

Oracle takes advantage of various types of processes:


• User process: Started at the time a database user
requests connection to the Oracle server
• Server process: Connects to the Oracle instance
and is started when a user establishes a session
• Background processes: Started when an Oracle
instance is started

1-28 Copyright © Oracle Corporation, 2002. All rights reserved.


User Process

• A program that requests interaction with the Oracle


server
• Must first establish a connection
• Does not interact directly with the Oracle server

Server
process
User
process
Connection
established

Database user

1-29 Copyright © Oracle Corporation, 2002. All rights reserved.


Server Process

• A program that directly interacts with the Oracle


server
• Fulfills calls generated and returns results
• Can be dedicated or shared server
Server
Connection process
established Session created
User Oracle server
process

Database user

1-30 Copyright © Oracle Corporation, 2002. All rights reserved.


Background Processes

Maintains and enforces relationships between physical


and memory structures:
• Mandatory background processes:
DBWn PMON CKPT
LGWR SMON
• Optional background processes:
ARCn LMDn QMNn
CJQ0 LMON RECO
Dnnn LMS Snnn
LCKn Pnnn

1-31 Copyright © Oracle Corporation, 2002. All rights reserved.


Database Writer (DBWn)

Instance DBWn writes when:


SGA • Checkpoint occurs
Database • Dirty buffers reach
Buffer threshold
Cache
• There are no free buffers
• Timeout occurs
DBWn
• RAC ping request is made
• Tablespace OFFLINE
• Tablespace READ ONLY
Redo
Data Control Log • Table DROP or TRUNCATE
files files files • Tablespace BEGIN
BACKUP
Database

1-32 Copyright © Oracle Corporation, 2002. All rights reserved.


Log Writer (LGWR)

Instance LGWR writes:


SGA • At commit
Redo Log
• When one-third full
Buffer
• When there is 1 MB of
redo
DBWn LGWR • Every three seconds
• Before DBWn writes

Redo
Data Control Log
files files files

Database

1-33 Copyright © Oracle Corporation, 2002. All rights reserved.


System Monitor (SMON)
Instance Responsibilities:
SGA
• Instance recovery
– Rolls forward
changes in online
redo log files
SMON – Opens database
for user access
Redo
– Rolls back
Data Control Log uncommitted
files files files
transactions
• Coalesces free space
Database
• Deallocates
temporary segments

1-34 Copyright © Oracle Corporation, 2002. All rights reserved.


Process Monitor (PMON)
Instance Cleans up after failed
SGA processes by:
• Rolling back the
transaction
• Releasing locks
PMON • Releasing other
resources
• Restarting dead
dispatchers
PGA area

1-35 Copyright © Oracle Corporation, 2002. All rights reserved.


Checkpoint (CKPT)
Instance
SGA
Responsible for:
• Signaling DBWn at
checkpoints
• Updating datafile
headers with
DBWn LGWR CKPT
checkpoint
information
• Updating control
Redo
Data Control Log files with checkpoint
files files files information

Database

1-36 Copyright © Oracle Corporation, 2002. All rights reserved.


Archiver (ARCn)

• Optional background process


• Automatically archives online redo log files when
ARCHIVELOG mode is set
• Preserves the record of all changes made to the
database

Redo ARCn
Data Control log Archived
files files redo log
files files

1-37 Copyright © Oracle Corporation, 2002. All rights reserved.


Logical Structure

• Dictates how the physical space of a database is


used
• Hierarchy consisting of tablespaces, segments,
extents, and blocks
Tablespace

Datafile
Segment Segment

Extent Blocks

1-39 Copyright © Oracle Corporation, 2002. All rights reserved.


Processing SQL Statements

• Connect to an instance using:


– User process
– Server process
• The Oracle server components that are used depend
on the type of SQL statement:
– Queries return rows
– DML statements log changes
– Commit ensures transaction recovery
• Some Oracle server components do not participate
in SQL statement processing.

1-42 Copyright © Oracle Corporation, 2002. All rights reserved.


Summary

In this lesson, you should have learned how to:


• Explain database files: data files, control files,
online redo log files
• Explain SGA memory structures: Database Buffer
Cache, Shared Pool, and Redo Log Buffer
• Explain primary background processes:
DBWn, LGWR, CKPT, PMON, SMON
• Explain the use of the optional background process
ARCn
• Identify optional and conditional background
processes
• Explain logical hierarchy

1-44 Copyright © Oracle Corporation, 2002. All rights reserved.


Practice 1 Overview

This practice covers the following topics:


• Reviewing architectural components
• Identifying structures involved in connecting a user
to an Oracle instance

1-45 Copyright © Oracle Corporation, 2002. All rights reserved.

You might also like