Sunday, August 19, 2012

Oracle Database Startup and Shutdown Process


Oracle Database Startup / Shutdown process

Starting/shutting down a oracle database seems very simple for new DBA’s, just connect and put “startup” or “shutdown immediate” command, but a thorough understanding of its stages is needed to be able to troubleshoot startup and shutdown related issues. It is mandatory for any Oracle DBA to have proper understanding of startup and shutdown process.

Starting up Oracle Database:

 To start a oracle database you need to login as “sysdba”, on “startup” command found in sql prompt it search for parameter file (spfile) to get configuration of oracle instance. The path of parameter file located by referring environment variable on the system (ORACLE_HOME, ORACLE_SID..). Oracle Database startup process consists of three stages.
Stage 1: NOMOUNT      => startup nomount
Stage 2: MOUNT           => startup mount
Stage 3: OPEN             => startup
When we fire “startup” command once connected as sysdba, in the background above three stages are followed to open the database.

 $sqlplus / as sysdba
 SQL>startup

ORACLE instance started.
Total System Global Area  732352512 bytes
Fixed Size            1339036 bytes
Variable Size          440402276 bytes
Database Buffers      285212672 bytes
Redo Buffers            5398528 bytes
Database mounted.
Database opened.                                                                                                                                                                                          
As you can see it the startup command automatically takes the database in Open mode. However some operations, like restores and recovers require decomposing the startup process. In this case switching up from one mode to the next one is done using an "alter database" command.
Three stages and process of bringing oracle database up is described as follows.

1.     “Nomount” Stage:

This is the first stage in the startup process.  You can start Oracle database in nomount mode using the command

SQL>startup nomount
ORACLE instance started.

Total System Global Area  732352512 bytes
Fixed Size            1339036 bytes
Variable Size          440402276 bytes
Database Buffers      285212672 bytes
Redo Buffers            5398528 bytes

When you execute the above command, an Oracle instance is started. When instance starts it will read the initialisation file (commonly known as parameter file) called init.ora file. From this parameter file the instance will know about the size of SGA, PGA, database buffer size and other configurable parameters. The instance will also start the Oracle background process such as (PMON, SMON, LGWR etc). This stage also opens the alert log and the trace files.
Check the running process
oracle@vmoratest1:/home/oracle/ [DBC] ps -ef |grep DBC
oracle    3999     1  0 09:12 ?        00:00:00 ora_pmon_DBC
oracle    4001     1  0 09:12 ?        00:00:00 ora_vktm_DBC
oracle    4005     1  0 09:12 ?        00:00:00 ora_gen0_DBC
oracle    4007     1  0 09:12 ?        00:00:00 ora_diag_DBC
oracle    4009     1  0 09:12 ?        00:00:00 ora_dbrm_DBC
oracle    4011     1  0 09:12 ?        00:00:00 ora_psp0_DBC
oracle    4013     1  0 09:12 ?        00:00:00 ora_dia0_DBC
oracle    4015     1  1 09:12 ?        00:00:00 ora_mman_DBC
oracle    4017     1  0 09:12 ?        00:00:00 ora_dbw0_DBC
oracle    4019     1  0 09:12 ?        00:00:00 ora_lgwr_DBC
oracle    4021     1  0 09:12 ?        00:00:00 ora_ckpt_DBC
oracle    4023     1  0 09:12 ?        00:00:00 ora_smon_DBC
oracle    4025     1  0 09:12 ?        00:00:00 ora_reco_DBC
oracle    4027     1  0 09:12 ?        00:00:00 ora_mmon_DBC
oracle    4029     1  0 09:12 ?        00:00:00 ora_mmnl_DBC
oracle    4031     1  0 09:12 ?        00:00:00 ora_d000_DBC
oracle    4033     1  0 09:12 ?        00:00:00 ora_s000_DBC
oracle    4106  3356  0 09:12 pts/1    00:00:00 grep DBC

Instance in NOMOUNT mode, it is only possible to access and interact to the spfile information

SQL> show parameter name

NAME                                                         TYPE       VALUE
--------------------------------                     ---------- ------------------------------
db_file_name_convert                         string
db_name                                                string         ULTHAN
db_unique_name                                 string        ULTHAN_SITE1
global_names                                        boolean    FALSE
instance_name                                    string          DBC
lock_name_space                                 string
log_file_name_convert                        string
service_names                                      string         DBC.it.dhu-domain.com

SQL> show parameter spfile;

NAME                       TYPE       VALUE
------------------------- ----------- ------------------------------
spfile                         string     /u00/app/oracle/admin/DBC/pfile/spfileDBC.ora

To access some instance views

SQL> select INSTANCE_NAME,HOST_NAME,STATUS from v$instance;

INSTANCE_NAME      HOST_NAME                         STATUS
-----------------         ---------------------------------               ------------
DBC                        vmoratest1.it.dhu-domain.com      STARTED

2.      Mount” Stage:

The next stage after NOMOUNT is called MOUNT. You can manually start an Oracle database in MOUNT stage using the command
SQL>startup mount
Or when database is already in nomount stage then you can change the stage by running the command
SQL>alter database mount;

When database goes into mount stage, it will read the control files specified in the parameter file. The control files contain the information about the physical structure of the database. So the control file will have the names and locations of all the datafiles and online redo log files. At this stage these datafiles and log files are not opened.
SQL> show parameter control_files

NAME                TYPE          VALUE
------------------- ------------- ----------------------------------------------------
control_files       string        /u01/oradata/DBC/control01DBC.dbf, /u02/oradata
                                              /DBC, /control02DBC.dbf,/u03/oradata/DBC  
                                             /control03DBC.dbf
Some DBA activities and maintenance can only be performed when the Oracle database is MOUNT stage. For example Oracle full database recovery can be done only when the database is in mount stage. If you want to rename a datafile you may need to take the database to mount stage unless the tablespace of the datafile is already offline.

SQL> select open_mode from v$database;

OPEN_MODE
--------------------
MOUNTED

SQL> select name from v$datafile;

NAME
--------------------------------------------------------------------------------
/u01/oradata/DBC/system01DBC.dbf
/u01/oradata/DBC/sysaux01DBC.dbf
/u01/oradata/DBC/undotbs01DBC.dbf
/u01/oradata/DBC/users01DBC.dbf

SQL>select member from v$logfile;

MEMBER
--------------------------------------------------------------------------------
/u01/oradata/DBC/redog1m1DBC.dbf
/u02/oradata/DBC/redog1m2DBC.dbf
/u01/oradata/DBC/redog2m1DBC.dbf
/u02/oradata/DBC/redog2m2DBC.dbf
/u01/oradata/DBC/redog3m1DBC.dbf
/u02/oradata/DBC/redog3m2DBC.dbf
6 rows selected.

3.     “Open” Stage:
The final stage in the Oracle startup process. When the database is open then only normal database operations can takes place. Which means users and applications can login and start reading/writing data.
Running the command below will start the Oracle database and put into OPEN stage.  
SQL>startup
And if the database is already in MOUNT stage then you can open the database using the command
SQL> alter database open;

Database altered.

SQL> select status,open_mode from v$instance,v$database;

STATUS         OPEN_MODE
-------------- --------------------
OPEN           READ WRITE

You can see above that database is opened in READ WRITE Mode , Database can also be opened in some special mode for specific purpose by DBA, namely Restricted, readonly.

SQL> startup restrict
ORACLE instance started.

Total System Global Area  732352512 bytes
Fixed Size            1339036 bytes
Variable Size          440402276 bytes
Database Buffers      285212672 bytes
Redo Buffers            5398528 bytes
Database mounted.
Database opened.

&

SQL> alter database open read only;
Database altered.

SQL> select open_mode from v$database;

OPEN_MODE
--------------------
READ ONLY

Shutting down Oracle Database:

There are four methods available to shutdown the oracle database:

  • Normal Shutdown
  • Shutdown transactional
  • Shutdown Immediate
  • Shutdown Abort


1. Normal Shutdown

During normal shutdown no new user connection will be allowed, before the oracle database is shut down, oracle will wait for all active users to finish its work, use this option to shutdown the database under normal conditions. This mode of shutdown may take minutes or hours.

SQL> shutdown
Database closed.
Database dismounted.
ORACLE instance shut down.

2. Shutdown Transactional

During Shutdown Transactional no new user connections are permitted and existing sessions that are not involved in active transactions will be terminated. However sessions currently involved in a transaction are allowed to complete the transaction and will then be terminated. Once all sessions are terminated, the database will shutdown.

3. Shutdown Immediate

During immediate shutdown, before the oracle database is shut down, oracle will rollback active transaction and disconnect all active users. Use this option when there is a problem with your database and you don’t have enough time to request users to log-off.

SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.

4. Shutdown Abort

shutdown abort is simply oracle instance crash, before the oracle database is shutdown, all user sessions will be terminated immediately. Uncomitted transactions will not be rolled back. Use this option only during emergency situations when the “shutdown” and “shutdown immediate” doesn’t work.
After a shutdown abort, the SMON process will have to perform an instance recovery at next startup.

$ sqlplus '/ as sysdba'
SQL*Plus: Release 10.2.0.3.0 - Production on Sun Jan 18 11:11:33 2009
Copyright (c) 1982, 2006, Oracle.  All Rights Reserved.
Connected to an idle instance.
SQL> shutdown abort
ORACLE instance shut down.