Search This Blog

23 April 2013

What happens when you shutdown a database internally

Whenever we have to shutdown a database, we would normally go by the golden rule – “The database shutdown has to consistent”. So we shutdown the database with either “shutdown” or “shutdown immediate” commands. Because we know if the database is shutdown normal or immediate, it won’t ask for recovery and would be in consistent state. So I just wondered what happens if I say “shutdown abort” at the SQL prompt. The answer would be – you will have database shut down in an inconsistent state.
So I just gave a try to identify what goes on in the background with the processes when we shutdown the database with different options.


Shutdown:


Whenever we say “shutdown” at the SQL prompt, the oracle process will wait for all the client connections to be closed before proceeding with the shutdown of the database. Once all the connections are closed, ckpt process will fire a complete checkpoint in which all the headers of the data files are freezed and updated with latest SCN. After the checkpoint is done, pmon process will come into action by cleaning the process variables and releasing the associated memory. Later smon will close the pmon process thereby bringing down the database. It also performs the cleaning up of the pmon process releasing memory associated with it.
So the database is shutdown normal without any inconsistencies.


Shutdown Immediate:


With shutdown immediate, in contrary to normal shutdown, the oracle process won’t wait for all the client connection to be closed; instead it will kill all the client connections. Once the client connections are closed, rest all processes continue to action as in with normal shutdown. Hence even when the database is shutdown using immediate option, the database is consistent.
Attached is the snapshot of alert log file:

Shutting down instance: further logons disabled
Shutting down instance (immediate)

– This is where all the connections are closed and PMON is invoked.

License high water mark = 10
Wed Aug 10 22:26:44 2005
ALTER DATABASE CLOSE NORMAL
Wed Aug 10 22:26:44 2005

– This is where PMON is closed and SMON is invoked.

SMON: disabling TX recovery
SMON: disabling cache recovery
Wed Aug 10 22:26:44 2005
Shutting down archive processes
Archiving is disabled
Archive process shutdown avoided: 0 active
Thread 1 closed at log sequence 1913
Successful close of redo thread 1.
Wed Aug 10 22:26:44 2005
Completed: ALTER DATABASE CLOSE NORMAL
Wed Aug 10 22:26:44 2005


Shutdown Abort:


So my real concern is with this option. What happens when the database is shutdown abort?
Whenever the database is shutdown using abort option, the ckpt process is by passed, thereby closing the oracle bequeath process. This in turn invokes pmon process to clean up the process and releases any memory associated with it, thus bringing the database down. Eventually as the ckpt process is not fired against the database before shutdown, the database will be in inconsistent state. Oracle does not recommend using this option.
Lets take a case study. Consider we have a database by name MAHESH.

The processes pertaining to the database would be:

$ ps –ef|grep MAHESH 
oracle10 26996 1 0 14:25:55 ? 0:00 ora_p001_MAHESH 
oracle10 26998 1 0 14:25:56 ? 0:00 ora_p002_MAHESH 
oracle10 26992 26960 0 14:25:55 ? 0:02 oracleMAHESH (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq))) 
oracle10 26974 1 0 14:25:50 ? 0:00 ora_psp0_MAHESH 
oracle10 26978 1 0 14:25:50 ? 0:00 ora_dbw0_MAHESH 
oracle10 26988 1 0 14:25:51 ? 0:01 ora_mmon_MAHESH 
oracle10 26990 1 0 14:25:51 ? 0:00 ora_mmnl_MAHESH 
oracle10 26994 1 0 14:25:55 ? 0:00 ora_p000_MAHESH 
oracle10 26980 1 0 14:25:51 ? 0:00 ora_lgwr_MAHESH 
oracle10 27018 27017 0 14:26:41 pts/9 0:00 grep MAHESH 
oracle10 26972 1 0 14:25:50 ? 0:00 ora_pmon_MAHESH 
oracle10 26986 1 0 14:25:51 ? 0:00 ora_reco_MAHESH 
oracle10 27000 1 0 14:25:57 ? 0:00 ora_qmnc_MAHESH 
oracle10 26976 1 0 14:25:50 ? 0:00 ora_mman_MAHESH 
oracle10 27014 1 0 14:26:12 ? 0:00 ora_q001_MAHESH 
oracle10 27007 1 0 14:26:07 ? 0:00 ora_q000_MAHESH 
oracle10 26982 1 0 14:25:51 ? 0:00 ora_ckpt_MAHESH 
oracle10 26984 1 0 14:25:51 ? 0:00 ora_smon_MAHESH

When the database is shutdown using abort option, the oracle bequeath process with pid 26992 is closed, thereby by passing the ckpt process and leaving the data file headers un-updated.

This could be clearly seen in the alert log of the MAHESH database:

Shutting down instance (abort)
License high water mark = 4
Instance terminated by USER, pid = 26992


Startup Force:

The startup force option internally shuts down the database and restarts it. So if you have a look at alert log of this, you will see that the database is shutdown using “shutdown abort” option and started normal. The database in this case would be in consistent state as it started up normal.

Tue Jul 31 14:54:50 2007
Shutting down instance (abort)
License high water mark = 4
Instance terminated by USER, pid = 27249
Tue Jul 31 14:54:52 2007
Starting ORACLE instance (normal)
Tue Jul 31 14:54:52 2007

Where pid 27249 is the oracle bequeath process id.

$ ps –ef|grep MAHESH 
oracle10 27249 26936 0 14:25:55 ? 0:02 oracleMAHESH (DESCRIPTION=(LOCAL=YES)(ADDRESS

For my remaining posts on Oracle DBA please click here