我想在每次启动ORACLE的时候都自动启动ORACLE 10G,请问应该怎么编写这个起动脚本?

解决方案 »

  1.   

    懒得翻译了:
    1.Log in as the root user.2.Edit the oratab file for your platform.To open the file, use one of the following commands:On Solaris:# vi /var/opt/oracle/oratabOn AIX, HP-UX, Linux, and Tru64 UNIX:# vi /etc/oratabDatabase entries in the oratab file are displayed in the following format:SID:ORACLE_HOME:{Y|N|W}In this example, the values Y and N specify whether you want the scripts to start up or shut down the database, respectively. For each database for which you want to automate shutdown and startup, first determine the instance identifier (SID) for that database, which is identified by the SID in the first field. Then, change the last field for each to Y.You can set dbstart to auto-start a single-instance database that uses an Automatic Storage Management installation that is auto-started by Oracle Clusterware. This is the default behavior for an Automatic Storage Management cluster. If you want to do this, then you must change the oratab entry of the database and the Automatic Storage Management installation to use a third field with the value W and N, respectively. These values specify that dbstart auto-starts the database only after the Automatic Storage Management instance is started.
    Note:If you add new database instances to the system and if you want to automate startup for them, then you must edit the entries for those instances in the oratab file. 
    3.Change directory to one of the following depending on your operating system:Platform Initialization File Directory 
    AIX /etc 
    Linux and Solaris /etc/init.d 
    HP-UX and Tru64 UNIX /sbin/init.d 
    4.Create a file called dbora, and copy the following lines into this file:
    Note:Change the value of the ORACLE_HOME environment variable to an Oracle home directory for the installation. Change the value of the ORACLE environment variable to the user name of the owner of the database installed in the Oracle home directory (typically, oracle). 
    #! /bin/sh  -x
    #
    # Change the value of ORACLE_HOME to specify the correct Oracle home
    # directory for your installation.ORACLE_HOME=/u01/app/oracle/product/10.2.0/db_1
    #
    # Change the value of ORACLE to the login name of the
    # oracle owner at your site.
    #
    ORACLE=oraclePATH=${PATH}:$ORACLE_HOME/bin
    HOST=`hostname`
    PLATFORM=`uname`
    export ORACLE_HOME PATH
    #
    if [ ! "$2" = "ORA_DB" ] ; then
       if [ "$PLATFORM" = "HP-UX" ] ; then
          remsh $HOST -l $ORACLE -n "$0 $1 ORA_DB"
          exit
       else
          rsh $HOST -l $ORACLE  $0 $1 ORA_DB
          exit
       fi
    fi
    #
    case $1 in
    'start')
            $ORACLE_HOME/bin/dbstart $ORACLE_HOME &
            ;;
    'stop')
            $ORACLE_HOME/bin/dbshut $ORACLE_HOME &
            ;;
    *)
            echo "usage: $0 {start|stop}"
            exit
            ;;
    esac
    #
    exit
    Note:This script can only stop Oracle Net listener for which a password has not been set. In addition, if the listener name is not the default name, LISTENER, then you must specify the listener name in the stop and start commands: 
    $ORACLE_HOME/bin/lsnrctl {start|stop} listener_name
     
    5.Change the group of the dbora file to the OSDBA group (typically dba), and set the permissions to 750:# chgrp dba dbora
    # chmod 750 dbora6.Create symbolic links to the dbora script in the appropriate run-level script directories as follows:Platform Symbolic Links Commands 
     
    Linux # ln -s /etc/init.d/dbora /etc/rc.d/rc3.d/K01dbora
    # ln -s /etc/init.d/dbora /etc/rc.d/rc3.d/S99dbora
    # ln -s /etc/init.d/dbora /etc/rc.d/rc5.d/K01dbora
    # ln -s /etc/init.d/dbora /etc/rc.d/rc5.d/S99dbora