Call now: 252-767-6166  
Oracle Training Oracle Support Development Oracle Apps

 
 Home
 E-mail Us
 Oracle Articles
New Oracle Articles


 Oracle Training
 Oracle Tips

 Oracle Forum
 Class Catalog


 Remote DBA
 Oracle Tuning
 Emergency 911
 RAC Support
 Apps Support
 Analysis
 Design
 Implementation
 Oracle Support


 SQL Tuning
 Security

 Oracle UNIX
 Oracle Linux
 Monitoring
 Remote s
upport
 Remote plans
 Remote
services
 Application Server

 Applications
 Oracle Forms
 Oracle Portal
 App Upgrades
 SQL Server
 Oracle Concepts
 Software Support

 Remote S
upport  
 Development  

 Implementation


 Consulting Staff
 Consulting Prices
 Help Wanted!

 


 Oracle Posters
 Oracle Books

 Oracle Scripts
 Ion
 Excel-DB  

Don Burleson Blog 


 

 

 


 

 

 
 

Windows Service Not Starting Your Database?

Oracle Tips by John Garmany

September 19,  2004

If you are on a Windows Server you need to know about the Windows Services and the oradim utility.

On all versions of Windows the Oracle Database (and the Application Server) are started as Windows Services.  This allows them to start in the background, normally owned by SYSTEM. 

In an earlier Tip I discussed starting and stopping the Application Server 10g on Windows using a script to start and stop the component's service.  The AS10g (and 9iAS) components can be started from the command line and will start the windows service however, the database (both the back end and the Metadata Repository) can not start without the database service running.

The Oracle Database must have a running service.

The Oracle database must attach itself to a running process.  It is the Win Service that provides this process.  Most DBAs think that the service is the database but that is not true.  The service can start/stop the database but it can also be started without starting the database.

Most Problem with the Win Service for the Database involve the service starting but the database not starting.

If the Win service is set to automatically start when the server boots but the database does not start, you may have a improper registry setting or you may have a bad service.

1.  Check Task Manager for the ORACLE.EXE process.  If it is present, then the service started.

2.  Check the Alert Log for the database.  If the problem is not with the database, there will be no indication in the log that the database even tried to start.

3.  Check the oradim.log in the $ORACLE_HOME/database directory for errors.  Check the date on the log file as versions before 9i did not date/time stamp the entries.

If there are no errors in the logs then try and start the database.

C:> sqlplus "/ as sysdba"
connected to an idle instance
SQL> starup

If the database starts great, the problem is in the service.

To check the Win service:

Open the registry with regedit.  Always back up the registry before making changes. Navigate to the key:

HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\oracle_home_name.

There will be a key called:

ORA_SID_AUTOSTART.  SID is your database SID.

This key should be set to TRUE.  If not the server starts but does not start the database.  There is also an ORA_SID_SHUTDOWN which you want to be TRUE so that if the server is shut down the service will shutdown the database.

If you want to manually start the database set ORA_SID_AUTOSTART to FALSE.  The service will start but not the database. 

Test the service.

If the ORA_SID_AUTOSTART setting was the problem, change it to TRUE and then test the service by stopping and then restarting the service to see it the database automatically starts.  If it does, then that fixed your problem......or maybe is didn't.  Reboot the server to verify that the database will start automatically.  Sometimes the service will work, only to fail again after a reboot.  If the service fail after rebooting you need to recreate it.  This is where the oradim utility comes in.

Deleting a Service

First delete or rename the oradim.log file.

Next delete the current service.

c:>oradim -delete -sid SID

SID is of course you database SID. This may take a while so check the services to insure that the OracleServiceSID is removed before proceeding.

Creating a new Service.

Again we use oradim to recreate the service.  This entire command is on one line.

c:> oradim -new -sid SID -intpwd password -startmode AUTO -pfile c:\oracle\admin\SID\pfile\initSID.ora

This command does a lot and will take some time to complete (if startmode is set to AUTO it will start the database).  It recreate the database password and sets the internal password to password. NOTE: oradim changes the internal password.

The startmode determines if the service starts the database when it starts.  If set to AUTO then the key ORA_SID_AUTOSTART is set to TRUE.  If startmode is MANUAL then the key is set to FALSE.

Check the oradim.log for errors.  Finally, verify the service works as needed by starting and stopping it.  Then test with a reboot.  If the service fails try recreating it again.

Scripting the Database Start in Windows

The dbstart and dbstop shell scripts do not exist on Windows platforms. Consequently Oracle database startup and shutdown is implemented completely differently. The oradim utility is used on the Windows platform to perform these tasks.

C:\oracle9i\bin\oradim -startup -sid ORCL92 ?usrpwd manager
-starttype SRVC,INST -pfile

C:\oracle9i\admin\ORCL92\pfile\init.ora


? startup ? Indicates that the specified instance should be started.
? sid ? The SID of the database to start.
? usrpwd ? The password for the database user.
? starttype ? Specifies whether to start the instance, the service, or both (SRVC, INST).

The following command can be used to shutdown the instance with oradim:

C:\oracle9i\bin\oradim -shutdown -sid ORCL92 -shutttype SRVC,INST
?shutmode A

Notice that no password is needed to perform this task.

If you can't get the service to function properly you are left with scripting the starting of the database.  Recreate the service with the -startmode set to MANUAL.  Then create a batch file as follows:

REM Wait for the server to start.
sleep 60
REM Start the database
%ORACLE_HOME%\bin\sqlplus -s "/ as sysdba" @startup.sql
exit

The startup.sql file

-- start the database
startup
exit

Now schedule the batch file in the Windows Scheduler to run at startup.

If this is part of you AS10g, you can implement the startup in the script used to start the application server components.

Also see:

oradim script download 

Oracle Windows oradim Utility

Auto start Oracle Automatically

Batch script to start Oracle Windows services

clipped from Google - 1/2012
Advanced Oracle Utilities - Oracle ORADIM Utility

How to start Oracle Windows services

Oracle Utilities Starting and Stopping Oracle on Windows

Oracle on Windows for Unix Users

 


 

 

��  
 
 
Oracle Training at Sea
 
 
 
 
oracle dba poster
 

 
Follow us on Twitter 
 
Oracle performance tuning software 
 
Oracle Linux poster
 
 
 

 

Burleson is the American Team

Note: This Oracle documentation was created as a support and Oracle training reference for use by our DBA performance tuning consulting professionals.  Feel free to ask questions on our Oracle forum.

Verify experience! Anyone considering using the services of an Oracle support expert should independently investigate their credentials and experience, and not rely on advertisements and self-proclaimed expertise. All legitimate Oracle experts publish their Oracle qualifications.

Errata?  Oracle technology is changing and we strive to update our BC Oracle support information.  If you find an error or have a suggestion for improving our content, we would appreciate your feedback.  Just  e-mail:  

and include the URL for the page.


                    









Burleson Consulting

The Oracle of Database Support

Oracle Performance Tuning

Remote DBA Services


 

Copyright © 1996 -  2020

All rights reserved by Burleson

Oracle ® is the registered trademark of Oracle Corporation.