SlideShare a Scribd company logo
1 of 47
Download to read offline
Introduction to Oracle | 1
Oracle Architecture
Introduction to Oracle | 2
Objects
• Describe Oracle Database architecture
• Explain memory structures
• Describe background processes
• Correlate logical and physical storage structures
Introduction to Oracle | 3
Oracle Database Innovation
Oracle Database Innovation
Private DB Cloud
Defense in Depth
Information Lifecycle Mgt
Extreme Availability
Flex Clusters
Performance and Ease of Use
Oracle Grid Infrastructure
Real Application Testing
Automatic SQL Tuning
Fault Management
Audit Vault
Database Vault
Secure Enterprise Search
Grid Computing
Automatic Storage Mgmt
… continuing with
Oracle Database 12c
… with Oracle Database 11g
… with Oracle
Database 10g
XML Database, Oracle Data Guard, RAC, Flashback Query, Virtual Private Database
Built-in Java VM , Partitioning Support, Built-in Messaging, Object Relational Support,
Multimedia Support
Introduction to Oracle | 4
Enterprise Cloud Computing
RAC
clusters
for
availability
Grids of
low-cost
hardware and
storage
Managing
change
across the
enterprise
Enterprise Manager
Cloud Control and
database
consolidation across
the enterprise
Introduction to Oracle | 5
• Oracle Database 10g: for grid computing.
• Oracle Database 11g: to deliver the benefits of grid computing,
transforming data centers from silos of isolated system resources to
shared pools of servers and storage.
• Oracle Database 12c and Enterprise Manager Cloud Control are
designed for cloud computing. The key benefits are the following:
– Reduce server sprawl and improve CPU utilization by consolidating on fewer
servers.
– Reduce the amount of time a DBA spends installing and configuring
databases, by automating deployment of standard database configurations.
– A single console manages the entire Cloud life cycle—plan, set up, deliver, and
operate.
– Prevent resource hogging by setting quotas for individual users.
– Forecast future resource needs by analyzing trending reports.
– Compute chargeback based on performance and configuration metrics.
Introduction to Oracle | 6
Course Examples: HR Sample Schema
REGIONS
REGION_ID (PK)
REGION_NAME
COUNTRIES
COUNTRY_ID (PK)
COUNTRY_NAME
REGION_ID (FK)
LOCATIONS
LOCATION_ID (PK)
STREET_ADDRESS
POSTAL_CODE
CITY
STATE_PROVINCE
COUNTRY_ID (FK)
DEPARTMENTS
DEPARTMENT_ID (PK)
DEPARTMENT_NAME
MANAGER_ID
LOCATION_ID (FK)
JOBS
JOB_ID (PK)
JOB_TITLE
MIN_SALARY
MAX_SALARY
EMPLOYEES
FIRST_NAME
LAST_NAME
EMAIL
PHONE_NUMBER
HIRE_DATE
JOB_ID (FK)
SALARY
COMMISION_PCT
MANAGER_ID (FK)
DEPARTMENT_ID (FK)
JOB_HISTORY
START_DATE (PK)
END_DATE
JOB_ID (FK)
DEPARTMENT_ID (FK)
REGIONS
COUNTRIES
LOCATIONS
DEPARTMENTS
JOBS
EMPLOYEES
EMPLOYEE_ID (PK)
JOB_HISTORY
EMPLOYEE_ID (PK)
Introduction to Oracle | 7
Oracle Database Server Architecture: Overview
Database (Storage Structures)
Server
process
PGA
User
process
Memory Structures
(System Global Area)
Instance
Process Structures
Client
Server
Introduction to Oracle | 8
Oracle Database Instance Configurations
D1
D2
I1
I2
I1 I2 I3
D
Clustered System
Nonclustered System
Local Storage
Shared Storage
Introduction to Oracle | 9
Connecting to the Database Instance
• Connection: Communication between a user process and an
instance
• Session: Specific connection of a user to an instance through a user
process
SQL> Select …
Session
User
User
process
Server
process
Connection
Session
Introduction to Oracle | 10
Oracle Database Memory Structures
• System Global Area (SGA): Group
of shared memory structures, known
as SGA components, that contain
data and control information for one
Oracle Database instance. The
SGA is shared by all server and
background processes. Examples of
data stored in the SGA include
cached data blocks and shared SQL
areas.
• Program Global Areas (PGA):
Memory regions that contain data
and control information for a server
or background process. A PGA is
nonshared memory created by
Oracle Database when a server or
background process is started.
Access to the PGA is exclusive to
the server process. Each server
process and background process
has its own PGA.
Server
process 1
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
Stack
Space
System Global Area (SGA)
Program Global Area (PGA)
Server
process2
User
Global
Area
User
Global
Area
PGA
Stack
Space
Fixed SGA
Redo log
buffer
Introduction to Oracle | 11
• Shared pool: Caches various constructs that can be shared among users
• Database buffer cache: Caches blocks of data retrieved from the database
• Redo log buffer: Caches redo information (used for instance recovery) until
it can be written to the physical redo log files stored on the disk
• Large pool: Optional area that provides large memory allocations for
certain large processes, such as Oracle backup and recovery operations,
and I/O server processes
• Java pool: Used for all session-specific Java code and data in the Java
Virtual Machine (JVM)
• Streams pool: Used by Oracle Streams to store information required by
capture and apply
• Fixed SGA: An internal housekeeping area containing general information
about the state of the database and the instance, and information
communicated between processes
Introduction to Oracle | 12
Shared Pool
• Is a portion of the SGA
• The shared pool portion of the SGA contains the library cache, the
data dictionary cache, the server result cache containing the SQL
query result cache and the PL/SQL function result cache, buffers
for parallel execution messages, and control structures.
• Contains:
– Library cache
• Shared SQL area
– Data dictionary cache
– Server result cache
Redo log
buffer
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
System Global Area (SGA)
Shared
SQLArea
Library
Cache
Data Dictionary
Cache
Server Result
Cache
Other
Reserved Pool
Fixed SGA
Introduction to Oracle | 13
• A shared SQL area contains the parse tree and execution plan for a
given SQL statement. Oracle Database saves memory by using one
shared SQL area for
• The data dictionary is a collection of database tables and views
containing reference information about the database, its structures,
and its users.
• The server result cache contains the SQL query result cache and
PL/SQL function result cache, which share the same infrastructure.
The server result cache contains result sets, not data blocks.
• The reserved pool is a memory area in the shared pool that Oracle
Database can use to allocate large contiguous chunks of memory.
Introduction to Oracle | 14
Database Buffer Cache
• Is part of the SGA
• Holds copies of data blocks that are read from data files
• Is shared by all concurrent users
Sharedpool
Database
buffer
cache
Streams
pool
Large pool Java pool
System Global Area (SGA)
Keep pool
Recycle
pool
nK buffer
cache
Fixed SGA
Redo log
buffer
The first time an Oracle Database user process requires a particular piece of data, it
searches for the data in the database buffer cache. If the process finds the data already
in the cache (a cache hit), it can read the data directly from memory. If the process
cannot find the data in the cache (a cache miss), it must copy the data block from a data
file on disk into a buffer in the cache before accessing the data. Accessing data through
a cache hit is faster than accessing data through a cachemiss.
Introduction to Oracle | 15
Redo Log Buffer
• Is a circular buffer in the SGA
• Holds information about changes made to the database
• Contains redo entries that have the information to redo changes
made by operations such as DML and DDL
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
System Global Area (SGA)
Redo log
buffer
Redo log
buffer
Fixed SGA
Introduction to Oracle | 16
Large Pool
• Provides large memory allocations for:
– Session memory for the shared server and the Oracle XA interface (used
where transactions interact with multiple databases)
– I/O server processes
– Oracle Database backup and restore operations
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
System Global Area (SGA)
RECYCLE
bufferpool
Fixed SGA
Redo log
buffer
Large pool
I/O buffer
Response
queue
Free
memory
Request
queue
Parallel
Query
Advanced
Queuing
The Oracle XA library is an external interface that allows global
transactions to be coordinated by a transaction manager other than
the Oracle8 Server.
Introduction to Oracle | 17
Java Pool
• Java pool memory is used to store all session-specific Java code
and data in the JVM (Java Virtual Machine).
Shared pool
Database buffer
cache
Streams
pool
ol
Largepo Java pool
System Global Area (SGA)
Java pool
Fixed SGA
Redo log
buffer
Introduction to Oracle | 18
Streams Pool
• Streams pool memory is used exclusively by Oracle Streams to:
– Store buffered queue messages
– Provide memory for Oracle Streams processes
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
System Global Area (SGA)
nK bu
cach
ffer
e
Redo log
buffer
Streams pool
Introduction to Oracle | 19
Program Global Area (PGA)
• The Program Global Area (PGA) is a private memory region containing
data and control information for a server process. Each server process
has a distinct PGA. Access to it is exclusive to that server process and it
is read only by Oracle code acting on behalf of it. It is not available for
developer’s code.
Server
process 1
PGA
Stack
Space
System Global Area (SGA)
Shared pool
Database
buffer
cache
Streams
pool
Large pool Java pool
User
Global
Area
User Session
Data
Cursor
State
Sort
Area
Hash
Area
Create BitmapArea
SQL
WorkAreas
Bitmap MergeArea
Fixed SGA
Redo log
buffer
Introduction to Oracle | 20
Process Architecture
• User process
– Is the application or tool that connects to the Oracle database
• Database processes
– Server process: Connects to the Oracle instance and is started when a user
establishes a session
– Background processes: Are started when an Oracle instance is started
• Daemon / Application processes (not specific to a single database)
– Networking listeners
– Grid Infrastructure daemons
Introduction to Oracle | 21
Process Structures
Instances (ASM and Databaseseparate)
System Global Area(SGA)
Background processes
Required: DBWn CKPT LGWR SMON PMON
RECO LREG MMON MMNL Others
Optional: ARCn Others
PGA
orarootagent
Grid Infrastructure Processes
(ASM and Oracle Restart)
ohas ocssd diskmon
oraagent cssdagent
User
process
Server
process
Listener
Introduction to Oracle | 22
Server Processes
• Oracle Database creates server processes to handle the requests of
user processes connected to the instance. The user process
represents the application or tool that connects to the Oracle
database. The user process first communicates with a listener
process that creates a server process in a dedicated environment.
• Server processes created on behalf of each user’s application can
perform one or more of the following:
– Parse and run SQL statements issued through the application.
– Read necessary data blocks from data files on disk into the shared database
buffers of the SGA (if the blocks are not already present in the SGA).
– Return results in such a way that the application can process the information.
Introduction to Oracle | 23
Background Processes
• To maximize performance and accommodate many users, a
multiprocess Oracle Database system uses some additional Oracle
Database processes called background processes. An Oracle
Database instance can have many background processes.
• Database Writerprocess (DBWn)
• Log Writer process (LGWR)
• Checkpoint process(CKPT)
• System monitor process (SMON)
• Process monitor process (PMON)
• Recoverer process (RECO)
• Listener registration process (LREG)
• Manageability monitor process (MMON)
• Manageability monitor lite process (MMNL)
• Job queue coordinator(CJQ0)
• Job slave processes(Jnnn)
• Archiver processes(ARCn)
• Queue monitor processes (QMNn)
Introduction to Oracle | 24
Database Writer Process (DBWn)
• Writes modified (dirty) buffers in the database buffer cache to disk:
– Asynchronously while performing other processing
– To advance the checkpoint
Database buffer
cache
Database Witer
process
Data files
DBWn
Introduction to Oracle | 25
Log Writer Process (LGWR)
• Writes the redo log buffer to a redo log file on disk
– When a user process commits a transaction
– When an online redo log switch occurs
– When the redo log buffer is one-third full or contains 1 MB of buffered data
– Before a DBWn process writes modified buffers to disk
– When three seconds have passed since the last write
• Serves as coordinator of LGnn processes and ensures correct order
for operations that must be ordered
Redo log files
LGWR
Redo log
buffer
LGnn
LGnn
Introduction to Oracle | 26
Checkpoint Process (CKPT)
• Records checkpoint information in
– Control file
– Each data file header
• Signals DBWn to write blocks to disk
Checkpoint
process
Data files
Control file
CKPT
Introduction to Oracle | 27
System Monitor Process (SMON)
• Performs recovery at instance startup
• Cleans up unused temporary segments
Instance
Temporary
segment
System Monitor
process
SMON
Introduction to Oracle | 28
Process Monitor Process (PMON)
• Performs process recovery when a user process fails
– Cleans up the database buffer cache
– Frees resources that are used by the user process
• Monitors sessions for idle session timeout
Process Monitor
process
Database buffer
cache
User
Failed user process
PMON
Server
process
Introduction to Oracle | 29
Recoverer Process (RECO)
• Used with the distributed database configuration
• Automatically connects to other databases involved in in- doubt
distributed transactions
• Automatically resolves all in-doubt transactions
• Removes any rows that correspond to in-doubt transactions
Recoverer process
in database A
In-doubt transaction
in database B
RECO
Introduction to Oracle | 30
Listener Registration Process (LREG)
• Registers information about the database instance and dispatcher
processes with the Oracle Net Listener
listener
Instance
Memory Structures
(System Global Area)
Process Structures
LREG
Introduction to Oracle | 31
Archiver Processes (ARCn)
• Copy redo log files to a designated storage device after a log switch
has occurred
• Can collect transaction redo data and transmit that data to standby
destinations
Archiver process Archive destination
Copies of redo log
files
ARCn
Introduction to Oracle | 32
Database Storage Architecture
Online redo log files
Password file
Parameter file Archived redo log
files
Control files Data files
Alert log and trace files
Backup files
Introduction to Oracle | 33
• Control files: Each database has one unique control file
that contains data about the database itself (that is,
physical database structure information). Multiple copies
may be maintained to protect against total loss. It can
also contain metadata related to backups. The control file
is critical to the database. Without the control file, the
database cannot be opened.
• Data files: Contain the user or application data of the
database, as well as metadata and the data dictionary
• Online redo log files: Allow for instance recovery of the
database. If the database server crashes and does not
lose any data files, the instance can recover the database
with the information in these files.
Control files
Data files
Online redo log files
Introduction to Oracle | 34
The following additional files are used during the operation
of the database:
• Parameter file: Is used to define how the instance is
configured when it starts up
• Password file: Allows users using the SYSDBA,
SYSOPER, SYSBACKUP, SYSDG, SYSKM, and
SYSASM roles to connect remotely to the instance and
perform administrative tasks
• Backup files: Are used for database recovery. You
typically restore a backup file when a media failure or
user error has damaged or deleted the original file. Backup files
Parameter file
Password file
Introduction to Oracle | 35
• Archived redo log files: Contain an ongoing history of
the data changes (redo) that are generated by the
instance. Using these files and a backup of the
database, you can recover a lost data file. That is,
archive logs enable the recovery of restored data files.
• Trace files: Each server and background process can
write to an associated trace file. When an internal error
is detected by a process, the process dumps information
about the error to its trace file.
• Alert log file: These are special trace entries. The alert
log of a database is a chronological log of messages
and errors. Oracle recommends that you review the alert
log periodically.
Archived redo log
files
Alert log and trace files
Introduction to Oracle | 36
Logical and Physical Database Structures
Logical Physical
Extent
Oracle data
block
• SAN
• NAS
• Exadata
• File System
• NFS
• ASM
Segment
Tablespace
Database
Data file
Storage System
Introduction to Oracle | 37
• Segments, Extents, and Blocks
– Segments exist in a tablespace.
• Segments are collections of extents.
– Extents are collections of data blocks.
– Data blocks are mapped to disk blocks.
Ref.: https://docs.oracle.com/cd/E11882_01/server.112/e40540/logical.htm#CNCPT1046
Segment Extents Data
blocks
Disk blocks
(File System
Storage)
Introduction to Oracle | 38
• Tablespaces and Data Files
– A database is divided into tablespaces, which are logical storage units that can
be used to group related logical structures. One or more data files are
explicitly created for each tablespace to physically store the data of all logical
structures in a tablespace.
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
8Kb 8Kb
Tablespace 1
Data file 1 Data file 2
Extent
64 KB
Extent
64 KB
Segment
128 KB
Tablespace 2 (Bigfile)
Data file 3
Only 1 data file
allowed
<= 128 TB
Introduction to Oracle | 39
SYSTEM and SYSAUX Tablespaces
• The SYSTEM and SYSAUX tablespaces are mandatory tablespaces
that are created at the time of database creation. They must be
online.
• The SYSTEM tablespace is used for core functionality (for example,
data dictionary tables).
• The auxiliary SYSAUX tablespace is used for additional database
components.
• The SYSTEM and SYSAUX tablespaces should not be used for
application data.
Introduction to Oracle | 40
Oracle Container Database: Introduction
• Pluggable database (PDB): Is a set of database schemas that
appears logically to users and applications as a separate database
• Multitenant container database (CDB): Has a database instance and
database files at the physical level
• All pluggable databases share:
– Background processes
– Shared/process memory
– Oracle metadata
Introduction to Oracle | 41
• Multitenant Architecture
Instance
Process Structures
Server
Instance
Multitenant
container
database
root container
Data files Control files Redo Log files
UNDO
TEMP
SYSTEM
SYSAUX
Data files
HR PDB
Data files
SYSTEM
TEMPO
SYSAUX
Seed PDB
Data files
SYSTEM
TEMP2
SYSAUX TBS2
SALES PDB
System Global Area
PDBid2 PDBid3 PDBid4 PDBid2 PDBid4
All PDBs share:
• Background
processes
• Shared/process
memory
• Oracle metadata
• Redo log files
• Control files
• Undo tablespace
Introduction to Oracle | 42
Automatic Storage Management - ASM
• Is a portable and high-performance cluster
file system
• Manages Oracle database files
• Manages application files with ASM Cluster
File System (ACFS)
• Spreads data across disks to balance load
• Mirrors data in case of failures
• Solves storage management challenges
ASM Cluster
File
System
ASM Dynamic
Volume Manager
Application
Oracle
Database
Operating system
ASM Files
for Oracle
Database
Automatic Storage Management
Introduction to Oracle | 43
• ASM Storage Components
Oracle
Database
Data file
ASM allocation
unit
ASM
disk group
ASM disk
ASM file
ASM
extent
File system
ASM
Introduction to Oracle | 44
Interacting with an Oracle Database: Memory,
Processes, and Storage
User
PGA
User
process
Server
process
Listener
Instance
Shared pool
Database
buffer
cache
Streams
pool
Large pool
Java pool
DBWn CKPT LGWR SMON PMON RECO ARCn Others
Redo log
buffer
Fixed SGA
Introduction to Oracle | 45
1. An instance has started on a node where Oracle Database is installed, often called the
host or database server.
2. A user starts an application spawning a user process. The application attempts to
establish a connection to the server. (The connection may be local, client/server, or a
three-tier connection from a middle tier.)
3. The server runs a listener that has the appropriate Oracle Net Services handler. The
listener detects the connection request from the application and creates a dedicated
server process on behalf of the user process.
4. The user runs a DML-type SQL statement and commits the transaction. For example,
the user changes the address of a customer in a table and commits the change.
5. The server process receives the statement and checks the shared pool (an SGA
component) for any shared SQL area that contains an identical SQL statement. If a
shared SQL area is found, the server process checks the user’s access privileges to the
requested data, and the existing shared SQL area is used to process the statement. If a
shared SQL area is not found, a new shared SQL area is allocated for the statement so
that itcan be parsed and processed.
Introduction to Oracle | 46
6. The server process retrieves any necessary data values, either from the actual data file
(table) or from values stored in the database buffer cache.
7. The server process modifies data in the SGA. Because the transaction is committed, the
Log Writer process (LGWR) immediately records the transaction in the redo log file. The
Database Writer process (DBWn) writes modified blocks permanently to disk when it is
efficient to do so.
8. If the transaction is successful, the server process sends a message across the network to
the application. If it is not successful, an error message is transmitted.
9. Throughout this entire procedure, the other background processes run, watching for
conditions that require intervention. In addition, the database server manages other users’
transactions and prevents contention between transactions that request the same data.
Introduction to Oracle | 47

More Related Content

Similar to Ora01_OraArc.pdf

Oracle Database 11g SQL Tuning Workshop - Student Guide.pdf
Oracle Database 11g SQL Tuning Workshop - Student Guide.pdfOracle Database 11g SQL Tuning Workshop - Student Guide.pdf
Oracle Database 11g SQL Tuning Workshop - Student Guide.pdf
Rajendra Jain
 
Oracle Cloud DBaaS
Oracle Cloud DBaaSOracle Cloud DBaaS
Oracle Cloud DBaaS
Arush Jain
 
Oracle Instance Architecture.ppt
Oracle Instance Architecture.pptOracle Instance Architecture.ppt
Oracle Instance Architecture.ppt
HODCA1
 

Similar to Ora01_OraArc.pdf (20)

Exploring the Oracle Database Architecture.ppt
Exploring the Oracle Database Architecture.pptExploring the Oracle Database Architecture.ppt
Exploring the Oracle Database Architecture.ppt
 
Oracle Database 11g SQL Tuning Workshop - Student Guide.pdf
Oracle Database 11g SQL Tuning Workshop - Student Guide.pdfOracle Database 11g SQL Tuning Workshop - Student Guide.pdf
Oracle Database 11g SQL Tuning Workshop - Student Guide.pdf
 
Introduction to oracle
Introduction to oracleIntroduction to oracle
Introduction to oracle
 
DBA 101 : Calling all New Database Administrators (PPT)
DBA 101 : Calling all New Database Administrators (PPT)DBA 101 : Calling all New Database Administrators (PPT)
DBA 101 : Calling all New Database Administrators (PPT)
 
An Introduction To Oracle Database
An Introduction To Oracle DatabaseAn Introduction To Oracle Database
An Introduction To Oracle Database
 
Less01 Dba1
Less01 Dba1Less01 Dba1
Less01 Dba1
 
Homework help on oracle
Homework help on oracleHomework help on oracle
Homework help on oracle
 
Lecture2 oracle ppt
Lecture2 oracle pptLecture2 oracle ppt
Lecture2 oracle ppt
 
What’s New in Oracle Database 19c - Part 1
What’s New in Oracle Database 19c - Part 1What’s New in Oracle Database 19c - Part 1
What’s New in Oracle Database 19c - Part 1
 
Oracle architecture
Oracle architectureOracle architecture
Oracle architecture
 
Oracle Cloud DBaaS
Oracle Cloud DBaaSOracle Cloud DBaaS
Oracle Cloud DBaaS
 
App D
App DApp D
App D
 
Oracle Instance Architecture.ppt
Oracle Instance Architecture.pptOracle Instance Architecture.ppt
Oracle Instance Architecture.ppt
 
ORACLE Architechture.ppt
ORACLE Architechture.pptORACLE Architechture.ppt
ORACLE Architechture.ppt
 
Oracle architecture ppt
Oracle architecture pptOracle architecture ppt
Oracle architecture ppt
 
Resize sga
Resize sgaResize sga
Resize sga
 
DBA 101 : Calling all New Database Administrators (WP)
DBA 101 : Calling all New Database Administrators (WP)DBA 101 : Calling all New Database Administrators (WP)
DBA 101 : Calling all New Database Administrators (WP)
 
VMworld 2013: Virtualizing Databases: Doing IT Right
VMworld 2013: Virtualizing Databases: Doing IT Right VMworld 2013: Virtualizing Databases: Doing IT Right
VMworld 2013: Virtualizing Databases: Doing IT Right
 
Ora 4 the_sqldba
Ora 4 the_sqldbaOra 4 the_sqldba
Ora 4 the_sqldba
 
The oracle database architecture
The oracle database architectureThe oracle database architecture
The oracle database architecture
 

Recently uploaded

Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
gajnagarg
 
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
Klinik kandungan
 
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
nirzagarg
 
Computer science Sql cheat sheet.pdf.pdf
Computer science Sql cheat sheet.pdf.pdfComputer science Sql cheat sheet.pdf.pdf
Computer science Sql cheat sheet.pdf.pdf
SayantanBiswas37
 
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
gajnagarg
 
Abortion pills in Jeddah | +966572737505 | Get Cytotec
Abortion pills in Jeddah | +966572737505 | Get CytotecAbortion pills in Jeddah | +966572737505 | Get Cytotec
Abortion pills in Jeddah | +966572737505 | Get Cytotec
Abortion pills in Riyadh +966572737505 get cytotec
 
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
gajnagarg
 
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
nirzagarg
 
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
nirzagarg
 
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
ZurliaSoop
 
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
gajnagarg
 

Recently uploaded (20)

Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
 
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
Jual obat aborsi Bandung ( 085657271886 ) Cytote pil telat bulan penggugur ka...
 
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
 
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
 
Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
 
Computer science Sql cheat sheet.pdf.pdf
Computer science Sql cheat sheet.pdf.pdfComputer science Sql cheat sheet.pdf.pdf
Computer science Sql cheat sheet.pdf.pdf
 
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Indore [ 7014168258 ] Call Me For Genuine Models We...
 
Top Call Girls in Balaghat 9332606886Call Girls Advance Cash On Delivery Ser...
Top Call Girls in Balaghat  9332606886Call Girls Advance Cash On Delivery Ser...Top Call Girls in Balaghat  9332606886Call Girls Advance Cash On Delivery Ser...
Top Call Girls in Balaghat 9332606886Call Girls Advance Cash On Delivery Ser...
 
Abortion pills in Jeddah | +966572737505 | Get Cytotec
Abortion pills in Jeddah | +966572737505 | Get CytotecAbortion pills in Jeddah | +966572737505 | Get Cytotec
Abortion pills in Jeddah | +966572737505 | Get Cytotec
 
Digital Transformation Playbook by Graham Ware
Digital Transformation Playbook by Graham WareDigital Transformation Playbook by Graham Ware
Digital Transformation Playbook by Graham Ware
 
Dubai Call Girls Peeing O525547819 Call Girls Dubai
Dubai Call Girls Peeing O525547819 Call Girls DubaiDubai Call Girls Peeing O525547819 Call Girls Dubai
Dubai Call Girls Peeing O525547819 Call Girls Dubai
 
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
Top profile Call Girls In Vadodara [ 7014168258 ] Call Me For Genuine Models ...
 
Gulbai Tekra * Cheap Call Girls In Ahmedabad Phone No 8005736733 Elite Escort...
Gulbai Tekra * Cheap Call Girls In Ahmedabad Phone No 8005736733 Elite Escort...Gulbai Tekra * Cheap Call Girls In Ahmedabad Phone No 8005736733 Elite Escort...
Gulbai Tekra * Cheap Call Girls In Ahmedabad Phone No 8005736733 Elite Escort...
 
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Begusarai [ 7014168258 ] Call Me For Genuine Models...
 
20240412-SmartCityIndex-2024-Full-Report.pdf
20240412-SmartCityIndex-2024-Full-Report.pdf20240412-SmartCityIndex-2024-Full-Report.pdf
20240412-SmartCityIndex-2024-Full-Report.pdf
 
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Tumkur [ 7014168258 ] Call Me For Genuine Models We...
 
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
 
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In Latur [ 7014168258 ] Call Me For Genuine Models We ...
 
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
 
Discover Why Less is More in B2B Research
Discover Why Less is More in B2B ResearchDiscover Why Less is More in B2B Research
Discover Why Less is More in B2B Research
 

Ora01_OraArc.pdf

  • 1. Introduction to Oracle | 1 Oracle Architecture
  • 2. Introduction to Oracle | 2 Objects • Describe Oracle Database architecture • Explain memory structures • Describe background processes • Correlate logical and physical storage structures
  • 3. Introduction to Oracle | 3 Oracle Database Innovation Oracle Database Innovation Private DB Cloud Defense in Depth Information Lifecycle Mgt Extreme Availability Flex Clusters Performance and Ease of Use Oracle Grid Infrastructure Real Application Testing Automatic SQL Tuning Fault Management Audit Vault Database Vault Secure Enterprise Search Grid Computing Automatic Storage Mgmt … continuing with Oracle Database 12c … with Oracle Database 11g … with Oracle Database 10g XML Database, Oracle Data Guard, RAC, Flashback Query, Virtual Private Database Built-in Java VM , Partitioning Support, Built-in Messaging, Object Relational Support, Multimedia Support
  • 4. Introduction to Oracle | 4 Enterprise Cloud Computing RAC clusters for availability Grids of low-cost hardware and storage Managing change across the enterprise Enterprise Manager Cloud Control and database consolidation across the enterprise
  • 5. Introduction to Oracle | 5 • Oracle Database 10g: for grid computing. • Oracle Database 11g: to deliver the benefits of grid computing, transforming data centers from silos of isolated system resources to shared pools of servers and storage. • Oracle Database 12c and Enterprise Manager Cloud Control are designed for cloud computing. The key benefits are the following: – Reduce server sprawl and improve CPU utilization by consolidating on fewer servers. – Reduce the amount of time a DBA spends installing and configuring databases, by automating deployment of standard database configurations. – A single console manages the entire Cloud life cycle—plan, set up, deliver, and operate. – Prevent resource hogging by setting quotas for individual users. – Forecast future resource needs by analyzing trending reports. – Compute chargeback based on performance and configuration metrics.
  • 6. Introduction to Oracle | 6 Course Examples: HR Sample Schema REGIONS REGION_ID (PK) REGION_NAME COUNTRIES COUNTRY_ID (PK) COUNTRY_NAME REGION_ID (FK) LOCATIONS LOCATION_ID (PK) STREET_ADDRESS POSTAL_CODE CITY STATE_PROVINCE COUNTRY_ID (FK) DEPARTMENTS DEPARTMENT_ID (PK) DEPARTMENT_NAME MANAGER_ID LOCATION_ID (FK) JOBS JOB_ID (PK) JOB_TITLE MIN_SALARY MAX_SALARY EMPLOYEES FIRST_NAME LAST_NAME EMAIL PHONE_NUMBER HIRE_DATE JOB_ID (FK) SALARY COMMISION_PCT MANAGER_ID (FK) DEPARTMENT_ID (FK) JOB_HISTORY START_DATE (PK) END_DATE JOB_ID (FK) DEPARTMENT_ID (FK) REGIONS COUNTRIES LOCATIONS DEPARTMENTS JOBS EMPLOYEES EMPLOYEE_ID (PK) JOB_HISTORY EMPLOYEE_ID (PK)
  • 7. Introduction to Oracle | 7 Oracle Database Server Architecture: Overview Database (Storage Structures) Server process PGA User process Memory Structures (System Global Area) Instance Process Structures Client Server
  • 8. Introduction to Oracle | 8 Oracle Database Instance Configurations D1 D2 I1 I2 I1 I2 I3 D Clustered System Nonclustered System Local Storage Shared Storage
  • 9. Introduction to Oracle | 9 Connecting to the Database Instance • Connection: Communication between a user process and an instance • Session: Specific connection of a user to an instance through a user process SQL> Select … Session User User process Server process Connection Session
  • 10. Introduction to Oracle | 10 Oracle Database Memory Structures • System Global Area (SGA): Group of shared memory structures, known as SGA components, that contain data and control information for one Oracle Database instance. The SGA is shared by all server and background processes. Examples of data stored in the SGA include cached data blocks and shared SQL areas. • Program Global Areas (PGA): Memory regions that contain data and control information for a server or background process. A PGA is nonshared memory created by Oracle Database when a server or background process is started. Access to the PGA is exclusive to the server process. Each server process and background process has its own PGA. Server process 1 Shared pool Database buffer cache Streams pool Large pool Java pool Stack Space System Global Area (SGA) Program Global Area (PGA) Server process2 User Global Area User Global Area PGA Stack Space Fixed SGA Redo log buffer
  • 11. Introduction to Oracle | 11 • Shared pool: Caches various constructs that can be shared among users • Database buffer cache: Caches blocks of data retrieved from the database • Redo log buffer: Caches redo information (used for instance recovery) until it can be written to the physical redo log files stored on the disk • Large pool: Optional area that provides large memory allocations for certain large processes, such as Oracle backup and recovery operations, and I/O server processes • Java pool: Used for all session-specific Java code and data in the Java Virtual Machine (JVM) • Streams pool: Used by Oracle Streams to store information required by capture and apply • Fixed SGA: An internal housekeeping area containing general information about the state of the database and the instance, and information communicated between processes
  • 12. Introduction to Oracle | 12 Shared Pool • Is a portion of the SGA • The shared pool portion of the SGA contains the library cache, the data dictionary cache, the server result cache containing the SQL query result cache and the PL/SQL function result cache, buffers for parallel execution messages, and control structures. • Contains: – Library cache • Shared SQL area – Data dictionary cache – Server result cache Redo log buffer Shared pool Database buffer cache Streams pool Large pool Java pool System Global Area (SGA) Shared SQLArea Library Cache Data Dictionary Cache Server Result Cache Other Reserved Pool Fixed SGA
  • 13. Introduction to Oracle | 13 • A shared SQL area contains the parse tree and execution plan for a given SQL statement. Oracle Database saves memory by using one shared SQL area for • The data dictionary is a collection of database tables and views containing reference information about the database, its structures, and its users. • The server result cache contains the SQL query result cache and PL/SQL function result cache, which share the same infrastructure. The server result cache contains result sets, not data blocks. • The reserved pool is a memory area in the shared pool that Oracle Database can use to allocate large contiguous chunks of memory.
  • 14. Introduction to Oracle | 14 Database Buffer Cache • Is part of the SGA • Holds copies of data blocks that are read from data files • Is shared by all concurrent users Sharedpool Database buffer cache Streams pool Large pool Java pool System Global Area (SGA) Keep pool Recycle pool nK buffer cache Fixed SGA Redo log buffer The first time an Oracle Database user process requires a particular piece of data, it searches for the data in the database buffer cache. If the process finds the data already in the cache (a cache hit), it can read the data directly from memory. If the process cannot find the data in the cache (a cache miss), it must copy the data block from a data file on disk into a buffer in the cache before accessing the data. Accessing data through a cache hit is faster than accessing data through a cachemiss.
  • 15. Introduction to Oracle | 15 Redo Log Buffer • Is a circular buffer in the SGA • Holds information about changes made to the database • Contains redo entries that have the information to redo changes made by operations such as DML and DDL Shared pool Database buffer cache Streams pool Large pool Java pool System Global Area (SGA) Redo log buffer Redo log buffer Fixed SGA
  • 16. Introduction to Oracle | 16 Large Pool • Provides large memory allocations for: – Session memory for the shared server and the Oracle XA interface (used where transactions interact with multiple databases) – I/O server processes – Oracle Database backup and restore operations Shared pool Database buffer cache Streams pool Large pool Java pool System Global Area (SGA) RECYCLE bufferpool Fixed SGA Redo log buffer Large pool I/O buffer Response queue Free memory Request queue Parallel Query Advanced Queuing The Oracle XA library is an external interface that allows global transactions to be coordinated by a transaction manager other than the Oracle8 Server.
  • 17. Introduction to Oracle | 17 Java Pool • Java pool memory is used to store all session-specific Java code and data in the JVM (Java Virtual Machine). Shared pool Database buffer cache Streams pool ol Largepo Java pool System Global Area (SGA) Java pool Fixed SGA Redo log buffer
  • 18. Introduction to Oracle | 18 Streams Pool • Streams pool memory is used exclusively by Oracle Streams to: – Store buffered queue messages – Provide memory for Oracle Streams processes Shared pool Database buffer cache Streams pool Large pool Java pool System Global Area (SGA) nK bu cach ffer e Redo log buffer Streams pool
  • 19. Introduction to Oracle | 19 Program Global Area (PGA) • The Program Global Area (PGA) is a private memory region containing data and control information for a server process. Each server process has a distinct PGA. Access to it is exclusive to that server process and it is read only by Oracle code acting on behalf of it. It is not available for developer’s code. Server process 1 PGA Stack Space System Global Area (SGA) Shared pool Database buffer cache Streams pool Large pool Java pool User Global Area User Session Data Cursor State Sort Area Hash Area Create BitmapArea SQL WorkAreas Bitmap MergeArea Fixed SGA Redo log buffer
  • 20. Introduction to Oracle | 20 Process Architecture • User process – Is the application or tool that connects to the Oracle database • Database processes – Server process: Connects to the Oracle instance and is started when a user establishes a session – Background processes: Are started when an Oracle instance is started • Daemon / Application processes (not specific to a single database) – Networking listeners – Grid Infrastructure daemons
  • 21. Introduction to Oracle | 21 Process Structures Instances (ASM and Databaseseparate) System Global Area(SGA) Background processes Required: DBWn CKPT LGWR SMON PMON RECO LREG MMON MMNL Others Optional: ARCn Others PGA orarootagent Grid Infrastructure Processes (ASM and Oracle Restart) ohas ocssd diskmon oraagent cssdagent User process Server process Listener
  • 22. Introduction to Oracle | 22 Server Processes • Oracle Database creates server processes to handle the requests of user processes connected to the instance. The user process represents the application or tool that connects to the Oracle database. The user process first communicates with a listener process that creates a server process in a dedicated environment. • Server processes created on behalf of each user’s application can perform one or more of the following: – Parse and run SQL statements issued through the application. – Read necessary data blocks from data files on disk into the shared database buffers of the SGA (if the blocks are not already present in the SGA). – Return results in such a way that the application can process the information.
  • 23. Introduction to Oracle | 23 Background Processes • To maximize performance and accommodate many users, a multiprocess Oracle Database system uses some additional Oracle Database processes called background processes. An Oracle Database instance can have many background processes. • Database Writerprocess (DBWn) • Log Writer process (LGWR) • Checkpoint process(CKPT) • System monitor process (SMON) • Process monitor process (PMON) • Recoverer process (RECO) • Listener registration process (LREG) • Manageability monitor process (MMON) • Manageability monitor lite process (MMNL) • Job queue coordinator(CJQ0) • Job slave processes(Jnnn) • Archiver processes(ARCn) • Queue monitor processes (QMNn)
  • 24. Introduction to Oracle | 24 Database Writer Process (DBWn) • Writes modified (dirty) buffers in the database buffer cache to disk: – Asynchronously while performing other processing – To advance the checkpoint Database buffer cache Database Witer process Data files DBWn
  • 25. Introduction to Oracle | 25 Log Writer Process (LGWR) • Writes the redo log buffer to a redo log file on disk – When a user process commits a transaction – When an online redo log switch occurs – When the redo log buffer is one-third full or contains 1 MB of buffered data – Before a DBWn process writes modified buffers to disk – When three seconds have passed since the last write • Serves as coordinator of LGnn processes and ensures correct order for operations that must be ordered Redo log files LGWR Redo log buffer LGnn LGnn
  • 26. Introduction to Oracle | 26 Checkpoint Process (CKPT) • Records checkpoint information in – Control file – Each data file header • Signals DBWn to write blocks to disk Checkpoint process Data files Control file CKPT
  • 27. Introduction to Oracle | 27 System Monitor Process (SMON) • Performs recovery at instance startup • Cleans up unused temporary segments Instance Temporary segment System Monitor process SMON
  • 28. Introduction to Oracle | 28 Process Monitor Process (PMON) • Performs process recovery when a user process fails – Cleans up the database buffer cache – Frees resources that are used by the user process • Monitors sessions for idle session timeout Process Monitor process Database buffer cache User Failed user process PMON Server process
  • 29. Introduction to Oracle | 29 Recoverer Process (RECO) • Used with the distributed database configuration • Automatically connects to other databases involved in in- doubt distributed transactions • Automatically resolves all in-doubt transactions • Removes any rows that correspond to in-doubt transactions Recoverer process in database A In-doubt transaction in database B RECO
  • 30. Introduction to Oracle | 30 Listener Registration Process (LREG) • Registers information about the database instance and dispatcher processes with the Oracle Net Listener listener Instance Memory Structures (System Global Area) Process Structures LREG
  • 31. Introduction to Oracle | 31 Archiver Processes (ARCn) • Copy redo log files to a designated storage device after a log switch has occurred • Can collect transaction redo data and transmit that data to standby destinations Archiver process Archive destination Copies of redo log files ARCn
  • 32. Introduction to Oracle | 32 Database Storage Architecture Online redo log files Password file Parameter file Archived redo log files Control files Data files Alert log and trace files Backup files
  • 33. Introduction to Oracle | 33 • Control files: Each database has one unique control file that contains data about the database itself (that is, physical database structure information). Multiple copies may be maintained to protect against total loss. It can also contain metadata related to backups. The control file is critical to the database. Without the control file, the database cannot be opened. • Data files: Contain the user or application data of the database, as well as metadata and the data dictionary • Online redo log files: Allow for instance recovery of the database. If the database server crashes and does not lose any data files, the instance can recover the database with the information in these files. Control files Data files Online redo log files
  • 34. Introduction to Oracle | 34 The following additional files are used during the operation of the database: • Parameter file: Is used to define how the instance is configured when it starts up • Password file: Allows users using the SYSDBA, SYSOPER, SYSBACKUP, SYSDG, SYSKM, and SYSASM roles to connect remotely to the instance and perform administrative tasks • Backup files: Are used for database recovery. You typically restore a backup file when a media failure or user error has damaged or deleted the original file. Backup files Parameter file Password file
  • 35. Introduction to Oracle | 35 • Archived redo log files: Contain an ongoing history of the data changes (redo) that are generated by the instance. Using these files and a backup of the database, you can recover a lost data file. That is, archive logs enable the recovery of restored data files. • Trace files: Each server and background process can write to an associated trace file. When an internal error is detected by a process, the process dumps information about the error to its trace file. • Alert log file: These are special trace entries. The alert log of a database is a chronological log of messages and errors. Oracle recommends that you review the alert log periodically. Archived redo log files Alert log and trace files
  • 36. Introduction to Oracle | 36 Logical and Physical Database Structures Logical Physical Extent Oracle data block • SAN • NAS • Exadata • File System • NFS • ASM Segment Tablespace Database Data file Storage System
  • 37. Introduction to Oracle | 37 • Segments, Extents, and Blocks – Segments exist in a tablespace. • Segments are collections of extents. – Extents are collections of data blocks. – Data blocks are mapped to disk blocks. Ref.: https://docs.oracle.com/cd/E11882_01/server.112/e40540/logical.htm#CNCPT1046 Segment Extents Data blocks Disk blocks (File System Storage)
  • 38. Introduction to Oracle | 38 • Tablespaces and Data Files – A database is divided into tablespaces, which are logical storage units that can be used to group related logical structures. One or more data files are explicitly created for each tablespace to physically store the data of all logical structures in a tablespace. 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb 8Kb Tablespace 1 Data file 1 Data file 2 Extent 64 KB Extent 64 KB Segment 128 KB Tablespace 2 (Bigfile) Data file 3 Only 1 data file allowed <= 128 TB
  • 39. Introduction to Oracle | 39 SYSTEM and SYSAUX Tablespaces • The SYSTEM and SYSAUX tablespaces are mandatory tablespaces that are created at the time of database creation. They must be online. • The SYSTEM tablespace is used for core functionality (for example, data dictionary tables). • The auxiliary SYSAUX tablespace is used for additional database components. • The SYSTEM and SYSAUX tablespaces should not be used for application data.
  • 40. Introduction to Oracle | 40 Oracle Container Database: Introduction • Pluggable database (PDB): Is a set of database schemas that appears logically to users and applications as a separate database • Multitenant container database (CDB): Has a database instance and database files at the physical level • All pluggable databases share: – Background processes – Shared/process memory – Oracle metadata
  • 41. Introduction to Oracle | 41 • Multitenant Architecture Instance Process Structures Server Instance Multitenant container database root container Data files Control files Redo Log files UNDO TEMP SYSTEM SYSAUX Data files HR PDB Data files SYSTEM TEMPO SYSAUX Seed PDB Data files SYSTEM TEMP2 SYSAUX TBS2 SALES PDB System Global Area PDBid2 PDBid3 PDBid4 PDBid2 PDBid4 All PDBs share: • Background processes • Shared/process memory • Oracle metadata • Redo log files • Control files • Undo tablespace
  • 42. Introduction to Oracle | 42 Automatic Storage Management - ASM • Is a portable and high-performance cluster file system • Manages Oracle database files • Manages application files with ASM Cluster File System (ACFS) • Spreads data across disks to balance load • Mirrors data in case of failures • Solves storage management challenges ASM Cluster File System ASM Dynamic Volume Manager Application Oracle Database Operating system ASM Files for Oracle Database Automatic Storage Management
  • 43. Introduction to Oracle | 43 • ASM Storage Components Oracle Database Data file ASM allocation unit ASM disk group ASM disk ASM file ASM extent File system ASM
  • 44. Introduction to Oracle | 44 Interacting with an Oracle Database: Memory, Processes, and Storage User PGA User process Server process Listener Instance Shared pool Database buffer cache Streams pool Large pool Java pool DBWn CKPT LGWR SMON PMON RECO ARCn Others Redo log buffer Fixed SGA
  • 45. Introduction to Oracle | 45 1. An instance has started on a node where Oracle Database is installed, often called the host or database server. 2. A user starts an application spawning a user process. The application attempts to establish a connection to the server. (The connection may be local, client/server, or a three-tier connection from a middle tier.) 3. The server runs a listener that has the appropriate Oracle Net Services handler. The listener detects the connection request from the application and creates a dedicated server process on behalf of the user process. 4. The user runs a DML-type SQL statement and commits the transaction. For example, the user changes the address of a customer in a table and commits the change. 5. The server process receives the statement and checks the shared pool (an SGA component) for any shared SQL area that contains an identical SQL statement. If a shared SQL area is found, the server process checks the user’s access privileges to the requested data, and the existing shared SQL area is used to process the statement. If a shared SQL area is not found, a new shared SQL area is allocated for the statement so that itcan be parsed and processed.
  • 46. Introduction to Oracle | 46 6. The server process retrieves any necessary data values, either from the actual data file (table) or from values stored in the database buffer cache. 7. The server process modifies data in the SGA. Because the transaction is committed, the Log Writer process (LGWR) immediately records the transaction in the redo log file. The Database Writer process (DBWn) writes modified blocks permanently to disk when it is efficient to do so. 8. If the transaction is successful, the server process sends a message across the network to the application. If it is not successful, an error message is transmitted. 9. Throughout this entire procedure, the other background processes run, watching for conditions that require intervention. In addition, the database server manages other users’ transactions and prevents contention between transactions that request the same data.