Sunday, August 4, 2013

Step By Step Manual Database Upgrade to 11gR2



Compatibility Matrix

Database Upgrade is common but risky task for a DBA if not done properly. Here, I am listing detailed method of upgrade with verification and validation.

Minimum Version of the Oracle database software that can be directly upgraded to Oracle 11g Release 2, so before upgrade remote DBA needs to check this.

Source Database                Target Database
9.2.0.8 or higher                    11.2.x
10.1.0.5 or higher                  11.2.x
10.2.0.2 or higher                  11.2.x
11.1.0.6 or higher                  11.2.x

The following database software version will require an indirect upgrade path. In this case DBA needs to do double effort, because two upgrades are needed.

Source Database ---> Upgrade Path for Target Database--->Target Database
7.3.3 (or lower)----->  7.3.4 ---->   9.2.0.8 ---->11.2.x
8.0.5 (or lower)---->    8.0.6 ---->   9.2.0.8 ---->11.2.x
8.1.7 (or lower)---->    8.1.7.4--->  10.2.0.4---->11.2.x
9.0.1.3 (or lower)----> 9.0.1.4--->  10.2.0.4---->11.2.x
9.2.0.7(or lower)---->9.2.0.8---->  11.2.x

Here I am upgrading my Oracle 10.2.0.4 database software to Oracle 11.2.0.3

1. Copy Pre upgrade Information gathering Script:

 Log in to the system as the owner of the Oracle Database 11g Release 2 (11.2) Oracle home directory.  Copy the Pre-Upgrade Information Tool (utlu112i.sql) and utltzuv2.sql from the Oracle Database 11g Release 2 (11.2) ORACLE_HOME/rdbms/admin directory to a directory outside of the Oracle home, such as the temporary directory on your system.


$ORACLE_HOME/rdbms/admin/utlu112i.sql

2. Execute Pre Upgrade Script:

Change to the directory where utlu112i.sql had been copied in the previous step.    Start SQL*Plus and connect to the database instance as a user with SYSDBA privileges. Then run and spool the utlu112i.sql file. Please note that the database should be started using the Source Oracle Home (i.e. from oracle 10g home).

$ sqlplus '/ as sysdba'
SQL> spool upgrade_info.log
SQL> @utlu112i.sql
SQL> spool off

Check the spool file and examine the output of the upgrade information tool.

 3. Check for the integrity of the source database:

Check for the integrity of the source database prior to starting the upgrade by downloading and running dbupgdiag.sql script from below My Oracle Support article
Note 556610.1  Script to Collect DB Upgrade/Migrate Diagnostic Information (dbupgdiag.sql) (Ignore  this step if you don’t have support access)

If the dbupgdiag.sql script reports any invalid objects, run $ORACLE_HOME/rdbms/admin/utlrp.sql (multiple times) to validate the invalid objects in the database, until there is no change in the number of invalid objects.
$ cd $ORACLE_HOME/rdbms/admin
$ sqlplus "/ as sysdba"
SQL> @utlrp.sql

After validating the invalid objects, re-run dbupgdiag.sql in the database once again and make sure that everything is fine.

4. Check that National Characterset:

Check that National Characterset (NLS_NCHAR_CHARACTERSET) is UTF8 and AL16UTF16.

select value from NLS_DATABASE_PARAMETERS where parameter = 'NLS_NCHAR_CHARACTERSET';

If this is UTF8 or AL16UTF16 then no action is needed.
If is not UTF8 or AL16UTF16 then refer the following article
Note 276914.1 The National Character Set in Oracle 9i and 10g.

5. Optimizer Statistics:

When upgrading to Oracle Database 11g Release 2 (11.2), optimizer statistics are collected for dictionary tables that lack statistics. This statistics collection can be time consuming for databases with a large number of dictionary tables, but statistics gathering only occurs for those tables that lack statistics or are significantly changed during the upgrade

$ sqlplus "/as sysdba"

SQL> EXEC DBMS_STATS.GATHER_DICTIONARY_STATS;

6. Ensure that no files need media recovery:

Sql> SELECT * FROM v$recover_file;

7. Stop the listener for the database:

Make pfile from spfile;

$ lsnrctl stop

8. Suhtdown the Database:
Shutdown the database.

$ sqlplus "/as sysdba"
SQL> shutdown immediate;

9. Back Up the Database:

1- Perform Cold Backup
(or)
2- Take a backup using RMAN

Connect to RMAN:

rman "target / nocatalog"

RUN
{
ALLOCATE CHANNEL chan_name TYPE DISK;
BACKUP DATABASE FORMAT '%U' TAG before_upgrade;
BACKUP CURRENT CONTROLFILE TO '';
}

10. Backup and change pfile:

Make a backup of the init.ora file.
Comment out obsolete parameters

* The DIAGNOSTIC_DEST initialization parameter replaces the USER_DUMP_DEST, BACKGROUND_DUMP_DEST.

Note: Once the Parameter file is modified as per your requirement, copy the file to $ORACLE_HOME/dbs (11g Oracle Home )


11. Set Environment Variables:

If your operating system is UNIX then complete this step, else skip to next Step.

1. Make sure the following environment variables point to the Oracle database software 11g Release directories:

- ORACLE_BASE
- ORACLE_HOME
- PATH
$ export ORACLE_HOME=
$ export PATH=$ORACLE_HOME/bin:$PATH
$ export ORACLE_BASE=
Note : If ORACLE_BASE is not known, after setting Path towards 11g Oracle Home, execute 'orabase', which will point the location of base.
$ orabase
/uo1/app/oracle

2. Update the oratab entry, to set the new ORACLE_HOME pointing towards ORCL and disable automatic startup

Sample /etc/oratab

#orcl:/opt/oracle/product/10.2/db_1:N
orcl:/opt/oracle/product/11.2/db_1:N

Note : After /etc/oratab is updated to have sid and Oracle Home (11.2), you can execute oraenv (/usr/local/bin/oraenv) and set the environment. The input has to be the sid which is entered in /etc/oratab against 11g home.
for Instance,

[oracle@localhost ~]$ . oraenv
ORACLE_SID = [orcl] ? orcl
The Oracle base for ORACLE_HOME=/opt/oracle/product/11.2/db_1 is /u01/app/oracle
[oracle@localhost ~]$

12. Upgrade Database:

At the operating system prompt, change to the $ORACLE_HOME/rdbms/admin directory of 11gR2 Oracle Home. Make sure that sqlplus is working from 11gR2 environment. Now start the upgrade processes as follows:-

$ cd $ORACLE_HOME/rdbms/admin
$ sqlplus "/ as sysdba"
SQL> startup UPGRADE

Set the system to spool results to a log file for later verification after the upgrade is completed and start the upgrade script.

SQL> set echo on
SQL> SPOOL upgrade.log
SQL> @catupgrd.sql
SQL> spool off

These measures are an important final step to ensure the integrity and consistency of the newly upgraded Oracle Database software. Also, if you encountered a message listing obsolete initialization parameters when you started the database for upgrade, then remove the obsolete initialization parameters from the parameter file before restarting. If necessary, convert the SPFILE to a PFILE so you can edit the file to delete parameters.

Post Upgrade Steps

13. Post Upgrade:

Start the database in 11g and run the Post-Upgrade Status Tool $ORACLE_HOME/rdbms/admin/utlu112s.sql which provides a summary of the upgrade at the end of the spool log. It displays the status of the database components in the upgraded database and the time required to complete each component upgrade. Any errors that occur during the upgrade are listed with each component and must be addressed
$ sqlplus "/as sysdba"
SQL> STARTUP
SQL> @utlu112s.sql

14. Recompile Invalid Objects:

This script can be run concurrently with utlrp.sql. Run utlrp.sql to recompile any remaining stored PL/SQL and Java code in another session.
SQL> @utlrp.sql

15. Check for the integrity of the source database:

Check for the integrity of the upgraded database by running dbupgdiag.sql script from below Metalink article.
Note 556610.1  Script to Collect DB Upgrade/Migrate Diagnostic Information (dbupgdiag.sql)
If the dbupgdiag.sql script reports any invalid objects, run $ORACLE_HOME/rdbms/admin/utlrp.sql (multiple times) to validate the invalid objects in the database, until there is no change in the number of invalid objects.

After validating the invalid objects, re-run dbupgdiag.sql in the upgraded database once again and make sure that everything is fine.

16. Configure and Start Listener.ora :

Modify the listener.ora file:

For the upgraded instance(s) modify the ORACLE_HOME parameter to point to the new ORACLE_HOME. Start the listener:

lsnrctl start

17. Crosscheck Environment Variables:

Set Environment Variables

1. Make sure the following environment variables point to the Oracle 11g Release directories:

- ORACLE_BASE
- ORACLE_HOME
- PATH

Also check that your oratab file and any client scripts that set the value of ORACLE_HOME point to the Oracle database software11g Release 2 (11.2) home.

Note : If you are upgrading a cluster database, then perform these checks on all nodes in which this cluster database has instances configured.

2. Modify /etc/oratab entry to use automatic startup
SID:ORACLE_HOME:Y

For Instance,
orcl:/opt/oracle/product/11.2/db_1:Y

18. Spfile from Pfile:
 Edit init.ora:

- If you changed the CLUSTER_DATABASE parameter prior the upgrade set it back to TRUE
- Migrate your initialization parameter file to a server parameter file.

Create a server parameter file with a initialization parameter file
SQL> create spfile from pfile;

This will create a spfile as a copy of the init.ora file located in $ORACLE_HOME/dbs (UNIX) & %ORACLE_HOME%\database (Windows).

19. Start the Database with spfile:
Shutdown the database:
Sql> shutdown immediate
Now start the database it will user spfile
Sql> startup
Check the Alert log file for any Error.

Database is ready to use now with Database Software Oracle 11g.

Sunday, June 23, 2013

Oracle 9i statspack

Take a snapshot

exec statspack.snap;

Or to specify a level...

exec statspack.snap(i_snap_level => 6, i_modify_parameter => 'true');


Level 0 - This level captures general statistics, including rollback segment, row cache, SGA, system events, background events, session events, system statistics, wait statistics, lock statistics, and Latch information.

Level 5 - This level includes capturing high resource usage SQL Statements, along with all data captured by lower levels.

Level 6 - This level includes capturing SQL plan and SQL plan usage information for high resource usage SQL Statements, along with all data captured by lower levels.

Level 7 - This level captures segment level statistics, including logical and physical reads, row lock, itl and buffer busy waits, along with all data captured by lower levels.

Level 10 - This level includes capturing Child Latch statistics, along with all data captured by lower levels.


Delete one or more snapshots

@?/rdbms/admin/sppurge;

Generate a report

@?/rdbms/admin/spreport.sql

List snapshots

col "Date/Time" format a30
select snap_id
, snap_level
, to_char(snap_time,'HH24:MI:SS DD-MM-YYYY') "Date/Time"
from stats$snapshot
, v$database
order by snap_id
/

Install statspack

1. Create a tablespace (minimum size 100MB)
2. Run...
@?/rdbms/admin/spcreate

Uninstall statspack

@?/rdbms/admin/spdrop

Schedule and hourly snapshot

@?/rdbms/admin/spauto.sql

Note. This uses dbms_job, so job_queue_processes needs to be set greater than 0.

To see the job:
select job
, what
from dba_jobs
/

To delete the job:
exec dbms_job.remove();

Saturday, June 22, 2013

AWR in Oracle

Display a list of snapshots

set lines 100 pages 999
select snap_id
, snap_level
, to_char(begin_interval_time, 'dd/mm/yy hh24:mi:ss') begin
from dba_hist_snapshot
order by 1
/

Produce a report

@?/rdbms/admin/awrrpt.sql

To see the snapshot interval and retention period

col snap_interval format a30
col retention format a30
select snap_interval
, retention
from dba_hist_wr_control
/

Change the snapshot interval

Note. This example changes it to 30 minutes
exec dbms_workload_repository.modify_snapshot_settings (interval => 30)

Change the retention period

Note. This example changes it to two weeks (14 days)
exec dbms_workload_repository.modify_snapshot_settings (retention => 14*24*60)

Manually take a snapshot

exec dbms_workload_repository.create_snapshot

List all baselines

set lines 100
col baseline_name format a40
select baseline_id
, baseline_name
, start_snap_id
, end_snap_id
from dba_hist_baseline
order by 1
/

Create a baseline

exec dbms_workload_repository.create_baseline (, ,'')

Remove a baseline

exec dbms_workload_repository.drop_baseline('')

Enable/Disable automatic snapshots

Note. This job is enabled by default
exec dbms_scheduler.enable('GATHER_STATS_JOB')

and to disable...
exec dbms_scheduler.disable('GATHER_STATS_JOB')

Time model queries

System time model
set lines 100 pages 999
select stat_name
, value
from v$sys_time_model
order by value desc
/

Session time model
set lines 100 pages 999
select stat_name
, value
from v$sess_time_model
where sid = '&sid'
order by value desc
/

Produce an Active Session History (ASH) report

@?/rdbms/admin/ashrpt.sql

2. Generate AWR reports for any instance in the cluster:
The script will ask you for the instance number in output format.
$ cd $ORACLE_HOME/rdbms/admin/
$ sqlplus sys as sysdba
SQL> @awrrpti.sql

From 11gr2 RAC We hav following options available:-
1.Generate AWR Cluster aggregated statistics from all the instances:
This report shows the aggregated statistics from the whole cluster database also, described as a global AWR cluster report
$ cd $ORACLE_HOME/rdbms/admin/
$ sqlplus sys as sysdba
SQL> @awrgrpt.sql

2. Generate AWR Global Cluster Difference Report:
Ths report compares the statistic results of differences between two different snapshot intervals, for the whole cluster database
$ cd $ORACLE_HOME/rdbms/admin/
$ sqlplus sys as sysdba
SQL> @awrgdrpt.sql

Export Data in Excel Format


set termout off

set newpage none

set pagesize 9999

set linesize 1024

set trimspool on

set trimout on

set echo off

set verify off

set heading off

set feedback off
spool tmp.sql
select 'set heading on' from dual;

select 'set termout off' from dual;
select 'set MARKUP HTML ON' from dual;

select 'set newpage none' from dual;
select 'set pagesize 9999' from dual;

select 'set linesize 1024' from dual;
select 'spool c:\table1.xls' from dual;
select 'column tablename format a30 heading "Tablename"' from dual;
select 'select ' || chr(39) || TABLE_NAME || chr(39) || ' as tablename from dual;' || chr(10) || chr(10) ||

'select * from ' || TABLE_NAME || ';' as sqlstmt from dba_tables where owner ='ABC' and table_name not like 'BIN$%' order by TABLE_NAME;



select 'spool off' from dual;
spool off
@tmp.sql
set termout on

exit

Oracle Background Processes

NameExpanded NameShort DescriptionLong DescriptionExternal Properties
ABMRAuto BMR Background ProcessCoordinates execution of tasks such as filtering duplicate block media recovery requests and performing flood controlWhen a process submits a block media recovery request to ABMR, it dynamically spawns slave processes (BMRn) to perform the recovery. ABMR and BMRn terminate after being idle for a long time.Database instance
ACFSASM Cluster File System CSS ProcessTracks the cluster membership in CSS and informs the file system driver of membership changesACFS delivers CSS membership changes to the Oracle cluster file system. These membership changes are required for the file system to maintain file system consistency within the cluster.ASM instance, Oracle RAC
ACMSAtomic Control File to Memory Service ProcessCoordinates consistent updates to a control file resource with its SGA counterpart on all instances in an Oracle RAC environmentThe ACMS process works with a coordinating caller to ensure that an operation is executed on every instance in Oracle RAC despite failures. ACMS is the process in which a distributed operation is called. As a result, this process can exhibit a variety of behaviors. In general, ACMS is limited to small, nonblocking state changes for a limited set of cross-instance operations.Database instance, Oracle RAC
APnnLogical Standby / Streams Apply Process Coordinator ProcessObtains transactions from the reader server and passes them to apply serversThe coordinator process name is APnn, where nn can include letters and numbers.Database instance, Data Guard, Oracle Streams
ARBnASM Rebalance ProcessRebalances data extents within an ASM disk groupPossible processes are ARB0-ARB9 and ARBA.ASM instance
ARCnArchiver ProcessCopies the redo log files to archival storage when they are full or an online redo log switch occursARCn processes exist only when the database is in ARCHIVELOG mode and automatic archiving is enabled, in which case ARCn automatically archives online redo log files. LGWR cannot reuse and overwrite an online redo log group until it has been archived.
The database starts multiple archiver processes as needed to ensure that the archiving of filled online redo logs does not fall behind. Possible processes include ARC0-ARC9 and ARCa-ARCt.
The LOG_ARCHIVE_MAX_PROCESSES initialization parameter specifies the number of ARCn processes that the database initially invokes.
Database instance
ASMBASM Background ProcessCommunicates with the ASM instance, managing storage and providing statisticsASMB runs in ASM instances when the ASMCMD cp command runs or when the database instance first starts if the server parameter file is stored in ASM. ASMB also runs with Oracle Cluster Registry on ASM.Database and ASM instances
ASnnLogical Standby / Streams Apply Process Reader Server or Apply Server
  • Computes dependencies between logical change records (LCRs) and assembles messages into transactions (Reader Server)
  • Applies LCRs to database objects or passes LCRs and user messages to their appropriate apply handlers (Apply Server)
When the reader server finishes computing dependencies between LCRs and assembling transactions, it returns the assembled transactions to the coordinator process. Query V$STREAMS_APPLY_READER for information about the reader server background process.
An apply server receives the transactions from the coordinator background process, and either applies database changes in LCRs or sends LCRs or messages to apply handlers. Apply servers can also enqueue a queue. If an apply server encounters an error, then it then tries to resolve the error with a user-specified conflict handler or error handler. If an apply server cannot resolve an error, then it rolls back the transaction and places the entire transaction, including all of its messages, in the error queue. When an apply server commits a completed transaction, this transaction has been applied. When an apply server places a transaction in the error queue and commits, this transaction also has been applied. QueryV$STREAMS_APPLY_SERVER for information about the apply server background process.
The coordinator process name is ASnn, where nn can include letters and numbers.
Database instance
BMRnAutomatic Block Media Recovery Slave Pool ProcessFetches blocks from a real-time readable standby databaseWhen a process submits a block media recovery request to ABMR, it dynamically spawns slave processes (BMRn) to perform the recovery. BMRnprocesses fetch blocks from a real-time readable standby database. ABMR and BMRn terminate after being idle for a long time.Database instance
BnnnASM Blocking Slave Process for GMONPerforms maintenance actions on ASM disk groupsBnnn performs actions that require waiting for resources on behalf of GMON. GMON must be highly available and cannot wait.
A Bnnn slave is spawned when a disk is taken offline in an ASM disk group. Offline timer processing and drop of the disk are performed in this slave. Up to five process (B000 to B004) can exist depending on the load.
ASM instance
CJQ0Job Queue Coordinator ProcessSelects jobs that need to be run from the data dictionary and spawns job queue slave processes (Jnnn) to run the jobsCJQ0 is automatically started and stopped as needed by Oracle Scheduler.
The JOB_QUEUE_PROCESSES initialization parameter specifies the maximum number of processes that can be created for the execution of jobs. CJQ0 starts only as many job queue processes as required by the number of jobs to run and available resources.
Database instance
CKPTCheckpoint ProcessSignals DBWn at checkpoints and updates all the data files and control files of the database to indicate the most recent checkpointAt specific times CKPT starts a checkpoint request by messaging DBWn to begin writing dirty buffers. On completion of individual checkpoint requests, CKPT updates data file headers and control files to record most recent checkpoint.Database and ASM instances
CPnnStreams Capture ProcessCaptures database changes from the redo log by using the infrastructure of LogMinerThe capture process name is CPnn, where nn can include letters and numbers. The underlying LogMiner process name is MSnn, where nn can include letters and numbers. The capture process includes one reader server that reads the redo log and divides it into regions, one or more preparer servers that scan the redo log, and one builder server that merges redo records from the preparer servers. Each reader server, preparer server, and builder server is a process. Query the V$STREAMS_CAPTURE view for information about this background process.Database instance, Oracle Streams
CSnnStreams Propagation Sender ProcessSends LCRs to a propagation receiverThe propagation sender process name is CSnn, where nn can include letters and numbers. In an Oracle Streams combined capture and apply optimization, the propagation sender sends LCRs directly to the propagation receiver to improve performance. The propagation receiver passes the LCRs to an apply process. Query V$PROPAGATION_SENDER for information about a propagation sender.Database instance, Oracle Streams
CSnnI/O Calibration ProcessIssues I/Os to storage as part of storage calibration.CSnn slave processes are started on execution of theDBMS_RESOURCE_MANAGER.CALIBRATE_IO()procedure. There is one slave process per CPU on each node of the database.Database instance, Oracle RAC
CTWRChange Tracking Writer ProcessTracks changed data blocks as part of the Recovery Manager block change tracking featureCTWR tracks changed blocks as redo is generated at a primary database and as redo is applied at a standby database. The process is slightly different depending on the type of database.Database instance
DBRMDatabase Resource Manager ProcessSets resource plans and performs other tasks related to the Database Resource ManagerIf a resource plan is not enabled, then this process is idle.Database instance
DBWnDatabase Writer ProcessWrites modified blocks from the database buffer cache to the data filesThe primary responsibility of DBWn is to write data blocks to disk. DBWn also handles checkpoints, file open synchronization, and logging of Block Written records.
In many cases the blocks that DBWn writes are scattered throughout the disk. Thus, the writes tend to be slower than the sequential writes performed by LGWR. DBWn performs multiblock writes when possible to improve efficiency. The number of blocks written in a multiblock write varies by operating system.
The DB_WRITER_PROCESSES initialization parameter specifies the number of DBWn processes (DBW0-DBW9 and DBWa-DBWz). The database selects an appropriate default setting for this parameter or adjusts a user-specified setting based on the number of CPUs and processor groups.
Database instance
DIA0Diagnostic ProcessDetects and resolves hangs and deadlocks
ASM and Database instances
DIAGDiagnostic Capture ProcessPerforms diagnostic dumpsDIAG performs diagnostic dumps requested by other processes and dumps triggered by process or instance termination. In Oracle RAC, DIAG performs global diagnostic dumps requested by remote instances.ASM and Database instances
DMnnData Pump Master ProcessCoordinates the Data Pump job tasks performed by Data Pump worker processes and handles client interactionsThe Data Pump master (control) process is started during job creation and coordinates all tasks performed by the Data Pump job. It handles all client interactions and communication, establishes all job contexts, and coordinates all worker process activities on behalf of the job.Database instance, Data Pump
DMONData Guard Broker Monitor ProcessManages and monitors a database that is part of a Data Guard broker configurationWhen you start the Data Guard broker, a DMON process is created. DMON runs for every database instance that is managed by the broker. DMON interacts with the local database and the DMON processes of the other databases to perform the requested function. DMON also monitors the health of the broker configuration and ensures that every database has a consistent description of the configuration.
DMON maintains profiles about all database objects in the broker configuration in a binary configuration file. A copy of this file is maintained by the DMON process for each of the databases that belong to the broker configuration. The process is created when the DG_BROKER_START initialization parameter is set totrue.
Database instance, Data Guard
DnnnDispatcher ProcessPerforms network communication in the shared server architectureIn the shared server architecture, clients connect to a dispatcher process, which creates a virtual circuit for each connection. When the client sends data to the server, the dispatcher receives the data into the virtual circuit and places the active circuit on the common queue to be picked up by an idle shared server. The shared server then reads the data from the virtual circuit and performs the database work necessary to complete the request. When the shared server must send data to the client, the server writes the data back into the virtual circuit and the dispatcher sends the data to the client. After the shared server completes the client request, the server releases the virtual circuit back to the dispatcher and is free to handle other clients.
Several initialization parameters relate to shared servers. The principal parameters are: DISPATCHERS,SHARED_SERVERSMAX_SHARED_SERVERS,LOCAL_LISTENERREMOTE_LISTENER.
Database instance, shared servers
DRnnASM Disk Resynchronization Slave ProcessResynchronizes the contents of an offline diskWhen a disk online SQL command is issued on a disk or disks that are offline, ASM spawns DRnn. Depending on the load, more than one slave may be spawned.ASM Instance
DSKMSlave Diskmon ProcessActs as the conduit between the database, ASM instances, and the Master Diskmon daemon to communicate information to Exadata storageThis process is active only if Exadata Storage is used. DSKM performs operations related to Exadata I/O fencing and Exadata cell failure handling.ASM instance, Exadata
DWnnData Pump Worker ProcessPerforms Data Pump tasks as assigned by the Data Pump master processThe Data Pump worker process is responsible for performing tasks that are assigned by the Data Pump master process, such as the loading and unloading of metadata and data.Database instance
EMNCEMON Coordinator ProcessCoordinates database event management and notificationsEMNC coordinates event management and notification activity in the database, including Streams Event Notifications, Continuous Query Notifications, and Fast Application Notifications.Database and ASM instances
EnnnEMON Slave ProcessPerforms database event management and notificationsThe database event management and notification load is distributed among the EMON slave processes. These processes work on the system notifications in parallel, offering a capability to process a larger volume of notifications, a faster response time, and a lower shared memory use for staging notifications.Database and ASM instances
FBDAFlashback Data Archiver ProcessArchives historical rows for tracked tables into flashback data archives and manages archive space, organization, and retentionWhen a transaction that modifies a tracked table commits, FBDA stores the pre-image of the rows in the archive. FDBA maintains metadata on the current rows and tracks how much data has been archived.
FBDA is also responsible for automatically managing the flashback data archive for space, organization (partitioning tablespaces), and retention. FBDA also keeps track of how far the archiving of tracked transactions has progressed.
Database and ASM instances
FMONFile Mapping Monitor ProcessManages mapping information for the Oracle Database file mapping interfaceThe DBMS_STORAGE_MAP package enables you to control the mapping operations. When instructed by the user, FMON builds mapping information and stores it in the SGA, refreshes the information when a change occurs, saves the information to the data dictionary, and restores it to the SGA at instance startup.
FMON is started by the database whenever the FILE_MAPPING initialization parameter is set to true.
Database and ASM instances
FSFPData Guard Broker Fast Start Failover Pinger ProcessMaintains fast-start failover state between the primary and target standby databasesFSFP is created when fast-start failover is enabled.Database instance, Data Guard
GCRnFoot 1 Global Conflict Resolution Slave ProcessPerforms synchronous tasks on behalf of LMHBGCRn processes are transient slaves that are started and stopped as required by LMHB to perform synchronous or resource intensive tasks.Database and ASM instances, Oracle RAC
GEN0General Task Execution ProcessPerforms required tasks including SQL and DML
Database and ASM instances
GMONASM Disk Group Monitor ProcessMonitors all mounted ASM disk groupsGMON monitors all the disk groups mounted in an ASM instance and is responsible for maintaining consistent disk membership and status information. Membership changes result from adding and dropping disks, whereas disk status changes result from taking disks offline or bringing them online.ASM instance
GTXnGlobal Transaction ProcessProvides transparent support for XA global transactions in an Oracle RAC environmentThese processes help maintain the global information about XA global transactions throughout the cluster. Also, the processes help perform two-phase commit for global transactions anywhere in the cluster so that an Oracle RAC database behaves as a single system to the externally coordinated distributed transactions.
The GLOBAL_TXN_PROCESSES initialization parameter specifies the number of GTXn processes, where n is 0-9 or a-j. The database automatically tunes the number of these processes based on the workload of XA global transactions. You can disable these processes by setting the parameter to 0. If you try to run XA global transactions with these process disabled, an error is returned.
Database instance, Oracle RAC
InnnDisk and Tape I/O Slave ProcessServes as an I/O slave process spawned on behalf of DBWR, LGWR, or an RMAN backup sessionI/O slave process can be configured on platforms where asynchronous I/O support is not available. These slaves are started by setting the corresponding slave enable parameter in the server parameter file. The I/O slaves simulate the asynchronous I/O behavior when the underlying platform does not have native support for asynchronous I/O.Database instance
INSVData Guard Broker Instance Slave ProcessPerforms Data Guard broker communication among instances in an Oracle RAC environmentINSV is created when the DG_BROKER_START initialization parameter is set totrue.Database instance, Data Guard
JnnnJob Queue Slave ProcessExecutes jobs assigned by the job coordinatorJob slave processes are created or awakened by the job coordinator when it is time for a job to be executed.
Job slaves gather all the metadata required to run the job from the data dictionary. The slave processes start a database session as the owner of the job, execute triggers, and then execute the job. After the job is complete, the slave processes commit and then execute appropriate triggers and close the session. The slave can repeat this operation in case additional jobs need to be run.
Database instance
LCK0Instance Enqueue Background ProcessManages global enqueue requests and cross-instance broadcastsThe process handles all requests for resources other than data blocks. For examples, LCK0 manages library and row cache requests.Database and ASM instances, Oracle RAC
LGWRLog Writer ProcessWrites redo entries to the online redo logRedo log entries are generated in the redo log buffer of the system global area (SGA). LGWR writes the redo log entries sequentially into a redo log file. If the database has a multiplexed redo log, then LGWR writes the redo log entries to a group of redo log files.Database and ASM instances
LMD0Global Enqueue Service Daemon 0 ProcessManages incoming remote resource requests from other instancesLMD0 processes enqueue resources managed under Global Enqueue Service. In particular, LMD0 processes incoming enqueue request messages and controls access to global enqueues. It also performs distributed deadlock detections.Database and ASM instances, Oracle RAC
LMHBGlobal Cache/Enqueue Service Heartbeat MonitorMonitor the heartbeat of LMON, LMD, and LMSnprocessesLMHB monitors LMON, LMD, and LMSn processes to ensure they are running normally without blocking or spinning.Database and ASM instances, Oracle RAC
LMONGlobal Enqueue Service Monitor ProcessMonitors an Oracle RAC cluster to manage global resourcesLMON maintains instance membership within Oracle RAC. The process detects instance transitions and performs reconfiguration of GES and GCS resources.Database and ASM instances, Oracle RAC
LMSnGlobal Cache Service ProcessManages resources and provides resource control among Oracle RAC instancesLMS, where n is 0-9 or a-z, maintains a lock database for Global Cache Service (GCS) and buffer cache resources. This process receives, processes, and sends GCS requests, block transfers, and other GCS-related messages.Database and ASM instances, Oracle RAC
LSP0Logical Standby Coordinator ProcessSchedules transactions for Data Guard SQL ApplyLSP0 is the initial process created upon startup of Data Guard SQL Apply. In addition to managing LogMiner and Apply processes, LSP0 is responsible for maintaining inter-transaction dependencies and appropriately scheduling transactions with applier processes. LSP0 is also responsible for detecting and enabling runtime parameter changes for the SQL Apply product as a whole.Database instance, Data Guard
LSP1Logical Standby Dictionary Build ProcessPerforms a logical standby dictionary build on a primary databaseThe LSP1 process is spawned on a logical standby database that is intended to become the new primary database. A logical standby database becomes a primary database by means of switchover or failover. The dictionary is necessary for logical standby databases to interpret the redo of the new primary database.Database instance, Data Guard
LSP2Logical Standby Set Guard ProcessDetermines which database objects will be protected by the database guardThe LSP2 process is created as needed during startup of SQL Apply to update the list of objects that are protected by the database guard.Database instance, Data Guard
LnnnPooled Server ProcessHandles client requests in Database Resident Connection PoolingIn Database Resident Connection Pooling, clients connect to a connection broker process. When a connection becomes active, the connection broker hands off the connection to a compatible pooled server process. The pooled server process performs network communication directly on the client connection and processes requests until the client releases the server. After being released, the connection is returned to the broker for monitoring, leaving the server free to handle other clients.Database instance, Database Resident Connection Pooling
MARKMark AU for Resynchronization Coordinator ProcessMarks ASM allocation units as stale following a missed write to an offline diskMARK essentially tracks which extents require resynchronization for offline disks. This process runs in the database instance and is started when the database instance first begins using the ASM instance. If required, MARK can also be started on demand when disks go offline in the ASM redundancy disk group.Database and ASM instances
MMANMemory Manager ProcessServes as the instance memory managerThis process performs the resizing of memory components on the instance.Database and ASM instances
MMNLManageability Monitor Lite ProcessPerforms tasks relating to manageability, including active session history sampling and metrics computationMMNL performs many tasks relating to manageability, including session history capture and metrics computation.Database and ASM instances
MMONManageability Monitor ProcessPerforms or schedules many manageability tasksMMON performs many tasks related to manageability, including taking Automatic Workload Repository snapshots and performing Automatic Database Diagnostic Monitor analysis.Database and ASM instances
MnnnMMON Slave ProcessPerforms manageability tasks on behalf of MMONMnnn performs manageability tasks dispatched to them by MMON. Tasks performed include taking Automatic Workload Repository snapshots and Automatic Database Diagnostic Monitor analysis.Database and ASM instances
MRP0Managed Standby Recovery ProcessCoordinates the application of redo on a physical standby databaseMRP0 is spawned at the start of redo apply on a physical standby database. This process handles the extraction of redo and coordinates the application of that redo on a physical standby database.Database instance, Data Guard
MSnnLogMiner Worker ProcessReads redo log files and translates and assembles into transactionsMultiple MSnn processes can exists, where n is 0-9 or a-Z. A minimum of three MSnn processes work as a group to provide transactions to a LogMiner client, for example, a logical standby database. There may be more than one such group, for example, Downstream Capture sessions.Database instance, Logical Standby, Oracle Streams
NnnnConnection Broker ProcessMonitors idle connections and hands off active connections in Database Resident Connection PoolingIn Database Resident Connection Pooling, clients connect to a connection broker process. When a connection becomes active, the connection broker hands off the connection to a compatible pooled server process. The pooled server process performs network communication directly on the client connection and processes requests until the client releases the server. After being released, the connection is returned to the broker for monitoring, leaving the server free to handle other clients.Database instance, Database Resident Connection Pooling
NSAnRedo Transport NSA1 ProcessShips redo from current online redo logs to remote standby destinations configured for ASYNC transportNSAn can run as multiple processes, where n is 1-9 or A-V.Database instance, Data Guard
NSSnRedo Transport NSS1 ProcessActs as a slave for LGWR when SYNC transport is configured for a remote standby destinationNSSn can run as multiple processes, where n is 1-9 or A-V.Database instance, Data Guard
NSVnData Guard Broker NetSlave ProcessPerforms broker network communications between databases in a Data Guard environmentNSVn is created when a Data Guard broker configuration is enabled. There can be as many NSVnprocesses (where n is 0- 9 and A-U) created as there are databases in the Data Guard broker configuration.Database instance, Data Guard
OCFnASM CF Connection Pool ProcessMaintains a connection to the ASM instance for metadata operations
Database and ASM instances
OnnnASM Connection Pool ProcessMaintains a connection to the ASM instance for metadata operationsOnnn slave processes are spawned on demand. These processes communicate with the ASM instance.Database and ASM instances
PINGInterconnect Latency Measurement ProcessAssesses latencies associated with communications for each pair of cluster instancesEvery few seconds, the process in one instance sends messages to each instance. The message is received by PING on the target instance. The time for the round trip is measured and collected.Database and ASM instances, Oracle RAC
PMONProcess MonitorMonitors the other background processes and performs process recovery when a server or dispatcher process terminates abnormallyPMON periodically performs cleanup of all the following:
  • Processes that died abnormally
  • Sessions that were killed
  • Detached transactions that have exceeded their idle timeout
  • Detached network connections which have exceeded their idle timeout
In addition, PMON monitors, spawns, and stops the following as needed:
  • Dispatcher and shared server processes
  • Job queue processes
  • Pooled server processes for database resident connection pooling
  • Restartable background processes
PMON is also responsible for registering information about the instance and dispatcher processes with the network listener.
Database and ASM instances
PnnnParallel Query Slave ProcessPerform parallel execution of a SQL statement (query, DML, or DDL)Parallel Query has two components: a foreground process that acts as query coordinator and a set of parallel slaves (Pnnn) that are background processes. These background processes are spawned or reused during the start of a parallel statement. They receive and carry out units of work sent from the query coordinator.
The maximum number of Pnnn processes is controlled by the initialization parameterPARALLEL_MAX_SERVERS. Slave processes are numbered from 0 to the PARALLEL_MAX_SERVERS setting. If the query is a GV$ query, then these background processes are numbered backward, starting from PZ99.
Database and ASM instances
PRnnParallel Recovery ProcessPerforms tasks assigned by the coordinator process performing parallel recoveryPRnn serves as a slave process for the coordinator process performing parallel media recovery and carries out tasks assigned by the coordinator. The default number of these processes is based on number of CPUs.Database instance
PSP0Process Spawner ProcessSpawns Oracle background processes after initial instance startup
Database and ASM instances
QMNCAQ Coordinator ProcessMonitors AQQMNC is responsible for facilitating various background activities required by AQ and Oracle Streams: time management of messages, management of nonpersistent queues, cleanup of resources, and so on. QMNC dynamically spawns Qnnn processes as needed for performing these tasks.
Note that if the AQ_TM_PROCESSES initialization parameter is set to 0, this process will not start. The database writes the following message to the alert log: WARNING: AQ_TM_PROCESSES is set to 0. System might be adversely affected.
Database instance, Advanced Queuing
QnnnAQ Server Class ProcessPerforms various AQ-related background task for QMNCQnnn acts as a slave process for QMNC and carry out tasks assigned by QMNC. The number of these processes is dynamically managed by QMNC based on load.Database instance
RBALASM Rebalance Master ProcessCoordinates rebalance activityIn an ASM instance, it coordinates rebalance activity for disk groups. In a database instances, it manages ASM disk groups.Database and ASM instances
RCBGResult Cache Background ProcessHandles result cache messagesThis process is used for handling invalidation and other messages generated by server processes attached to other instances in Oracle RAC.Database instance, Oracle RAC
RECORecoverer ProcessResolves distributed transactions that are pending because of a network or system failure in a distributed databaseRECO uses the information in the pending transaction table to finalize the status of in-doubt transactions. At timed intervals, the local RECO attempts to connect to remote databases and automatically complete the commit or rollback of the local portion of any pending distributed transactions. All transactions automatically resolved by RECO are removed from the pending transaction table.Database instance
RMSnOracle RAC Management ProcessPerforms manageability tasks for Oracle RACRMSn performs a variety of tasks, including creating resources related to Oracle RAC when new instances are added to a cluster.Database instance, Oracle RAC
RnnnASM Block Remap Slave ProcessRemaps a block with a read errorA database instance reading from an ASM disk group can encounter an error during a read. If possible, ASM asynchronously schedules a Rnnn slave process to remap this bad block from a mirror copy.ASM instance
RPnnCapture Processing Worker ProcessProcesses a set of workload capture filesRPnn are worker processes spawned by callingDBMS_WORKLOAD_REPLAY.PROCESS_CAPTURE(capture_dir,parallel_level). Each worker process is assigned a set of workload capture files to process.
Worker processes execute in parallel without needing to communicate with each other. After each process is finished processing its assigned files, it exits and informs its parent process.
The number of worker processes is controlled by the parallel_levelparameter ofDBMS_WORKLOAD_REPLAY.PROCESS_CAPTURE. By default,parallel_level is null. Then, the number of worker processes is computed as follows:
SELECT VALUE
FROM   V$PARAMETER
WHERE  NAME='cpu_count';
When parallel_level is 1, no worker processes are spawned.
Database instance
RSM0Data Guard Broker Worker ProcessPerforms monitoring management tasks related to Data Guard on behalf of DMONThe process is created when a Data Guard broker configuration is enabled.Database instance, Data Guard
RSMNRemote Slave Monitor ProcessManages background slave process creation and communication on remote instances in Oracle RACThis background process manages the creation of slave processes and the communication with their coordinators and peers. These background slave processes perform tasks on behalf of a coordinating process running in another cluster instance.Database instance, Oracle RAC
RVWRRecovery Writer ProcessWrites flashback data to the flashback logs in the fast recovery areaRVWR writes flashback data from the flashback buffer in the SGA to the flashback logs. RVWR also creates flashback logs and performs some tasks for flashback log automatic management.Database instance, Flashback Database
SMCOSpace Management Coordinator ProcessCoordinates the execution of various space management tasksThis background process coordinates the execution of various space management tasks, including proactive space allocation and space reclamation. SMCO dynamically spawns slave processes (Wnnn) to implement these tasks.Database instance
SMONSystem Monitor ProcessPerforms critical tasks such as instance recovery and dead transaction recovery, and maintenance tasks such as temporary space reclamation, data dictionary cleanup, and undo tablespace managementSMON performs many database maintenance tasks, including the following:
  • Creates and manages the temporary tablespace metadata
  • Reclaims space used by orphaned temporary segments
  • Maintains the undo tablespace by onlining, offlining, and shrinking the undo segments based on undo space usage statistics
  • Cleans up the data dictionary when it is in a transient and inconsistent state
  • Maintains the SCN to time mapping table used to support Oracle Flashback features
In an Oracle RAC database, the SMON process of one instance can perform instance recovery for other instances that have failed.
SMON is resilient to internal and external errors raised during background activities.
Database instance
SnnnShared Server ProcessHandles client requests in the shared server architectureIn the shared server architecture, clients connect to a dispatcher process, which creates a virtual circuit for each connection. When the client sends data to the server, the dispatcher receives the data into the virtual circuit and places the active circuit on the common queue to be picked up by an idle shared server. The shared server then reads the data from the virtual circuit and performs the database work necessary to complete the request. When the shared server must send data to the client, the server writes the data back into the virtual circuit and the dispatcher sends the data to the client. After the shared server completes the client request, the server releases the virtual circuit back to the dispatcher and is free to handle other clients.
Several initialization parameters relate to shared servers. The principal parameters are: DISPATCHERS,SHARED_SERVERSMAX_SHARED_SERVERS,LOCAL_LISTENERREMOTE_LISTENER.
Database instance, shared servers
TEMnASM disk Test Error Emulation ProcessEmulates I/O errors on ASM disks through named eventsI/O errors can be emulated on ASM disk I/O through named events. The scope can be the process, instance, or even cluster. Optionally, a set of AUs can be chosen for error emulation.ASM instance
VBGnVolume Background ProcessCommunicates between the ASM instance and the operating system volume driverVBGn handles messages originating from the volume driver in the operating system and sends them to the ASM instance.
VBGn can run as multiple processes, where n is 0-9.
ASM instance
VDBGVolume Driver ProcessForwards ASM requests to perform various volume-related tasksVDBG handles requests to lock or unlock an extent for rebalancing, volume resize, disk offline, add or drop a disk, force and dismount disk group to the Dynamic Volume Manager driver.ASM instance
VKRMVirtual Scheduler for Resource Manager ProcessServes as centralized scheduler for Resource Manager activityVKRM manages the CPU scheduling for all managed Oracle processes. The process schedules managed processes in accordance with an active resource plan.Database instance
VKTMVirtual Keeper of Time ProcessProvides a wall clock time and reference time for time interval measurementsVKTM acts as a time publisher for an Oracle instance. VKTM publishes two sets of time: a wall clock time using a seconds interval and a higher resolution time (which is not wall clock time) for interval measurements. The VKTM timer service centralizes time tracking and offloads multiple timer calls from other clients.Database and ASM instances
VMB0Volume Membership ProcessMaintains cluster membership on behalf of the ASM volume driverThis process membership in the cluster as an I/O-capable client on behalf of the ASM volume driver.ASM instance
VnnnASM Volume I/O Slave ProcessInitializes ASM volume contents during creationThis process is responsible for initializing the ASM volume during creation.ASM instance
WnnnSpace Management Slave ProcessPerforms various background space management tasks, including proactive space allocation and space reclamationWnnn processes are slave processes dynamically spawned by SMCO to perform space management tasks in the background. These tasks include preallocating space into locally managed tablespace and SecureFiles segments based on space usage growth analysis, and reclaiming space from dropped segments. At most 10 Wnnn slaves can run on one database instance. After being started, the slave acts as an autonomous agent. After it finishes task execution, it automatically picks up another task from the queue. The process terminates itself after being idle for a long time.Database instance
XDMGExadata Automation ManagerInitiates automation tasks involved in managing Exadata storageXDMG monitors all configured Exadata cells for state changes, such as a bad disk getting replaced, and performs the required tasks for such events. Its primary tasks are to watch for inaccessible disks and cells and when they become accessible again, and to initiate the ASM ONLINE operation. The ONLINE operation is handled by XDWK.ASM instance, Exadata
XDWKExadata Automation ManagerPerforms automation tasks requested by XDMGXDWK gets started when asynchronous actions such as ONLINE, DROP, and ADD an ASM disk are requested by XDMG. After a 5 minute period of inactivity, this process will shut itself down.ASM instance, Exadata
XnnnASM Disk Expel Slave ProcessPerforms ASM post-rebalance activitiesThis process expels dropped disks at the end of an ASM rebalance.ASM instance

Followers