11 Adding and Deleting Oracle RAC from Nodes on Linux and UNIX Systems
Extend an existing Oracle Real Application Clusters (Oracle RAC) home to other nodes and instances in the cluster, and delete Oracle RAC from nodes and instances in the cluster.
If your goal is to clone an existing Oracle RAC home to create multiple new Oracle RAC installations across the cluster, then use the cloning procedures that are described in "Cloning Oracle RAC to Nodes in a New Cluster".
The topics in this chapter include the following:
Note:
- 
                        Ensure that you have a current backup of Oracle Cluster Registry (OCR) before adding or deleting Oracle RAC by running the ocrconfig -showbackupcommand.
- 
                        The phrase "target node" as used in this chapter refers to the node to which you plan to extend the Oracle RAC environment. 
Adding Oracle RAC to Nodes with Oracle Clusterware Installed
Before beginning this procedure, ensure that your existing nodes have the correct path to the Grid_home and that the $ORACLE_HOME environment variable is set to the Oracle RAC home.
                  
- 
                        If you are using a local (non-shared) Oracle home, then you must extend the Oracle RAC database home that is on an existing node ( node1in this procedure) to a target node (node3in this procedure).- 
                              
                              Navigate to the Oracle_home/addnodedirectory onnode1and run theaddnode.shscript.
- 
                              
                              If you want to perform a silent installation, run the addnode.shscript using the following syntax:$ ./addnode.sh -silent "CLUSTER_NEW_NODES={node3}"
- 
                              
                              
                              Run the Oracle_home/root.shscript onnode3asroot.
- 
                              
                              
                              Open the pluggable databases (PDBs) on the newly added node using the following commands in your SQL*Plus session: SQL> CONNECT / AS SYSDBA SQL> ALTER PLUGGABLE DATABASE pdb_name OPEN;
 
- 
                              
                              
- 
                        If you have a shared Oracle home that is shared using Oracle Automatic Storage Management Cluster File System (Oracle ACFS), then do the following to extend the Oracle database home to node3:- 
                              Start the Oracle ACFS resource on the new node by running the following command as rootfrom theGrid_home/bindirectory:# srvctl start filesystem -device volume_device [-node node_name]Note: Make sure the Oracle ACFS resources, including Oracle ACFS registry resource and Oracle ACFS file system resource where the Oracle home is located, are online on the newly added node. 
- 
                              Run the following command as the user that installed Oracle RAC from the Oracle_home/oui/bindirectory on the node you are adding to add the Oracle RAC database home:$ ./runInstaller -attachHome ORACLE_HOME="ORACLE_HOME" "CLUSTER_NODES={node3}" LOCAL_NODE="node3" ORACLE_HOME_NAME="home_name" -cfs
- 
                              Navigate to the Oracle_home/addnodedirectory onnode1and run theaddnode.shscript as the user that installed Oracle RAC using the following syntax:$ ./addnode.sh -noCopy "CLUSTER_NEW_NODES={node3}"Note: Use the -noCopyoption because the Oracle home on the destination node is already fully populated with software.
 
- 
                              
- 
                        If you have a shared Oracle home on a shared file system that is not Oracle ACFS, then you must first create a mount point for the Oracle RAC database home on the target node, mount and attach the Oracle RAC database home, and update the Oracle Inventory, as follows: - 
                              Run the srvctl config database -db db_namecommand on an existing node in the cluster to obtain the mount point information.
- 
                              Run the following command as rootonnode3to create the mount point:# mkdir -p mount_point_path
- 
                              Mount the file system that hosts the Oracle RAC database home. 
- 
                              Run the following command as the user that installed Oracle RAC from the Oracle_home/oui/bindirectory on the node you are adding to add the Oracle RAC database home:$ ./runInstaller -attachHome ORACLE_HOME="ORACLE_HOME" "CLUSTER_NODES= {local_node_name}" LOCAL_NODE="node_name" ORACLE_HOME_NAME="home_name"
- 
                              Update the Oracle Inventory as the user that installed Oracle RAC, as follows: $ ./runInstaller -updateNodeList ORACLE_HOME=mount_point_path "CLUSTER_NODES= {node_list}"In the preceding command, node_listrefers to a list of all nodes where the Oracle RAC database home is installed, including the node you are adding.
 
- 
                              
Run the Oracle_home/root.sh script on node3 as root.
                  
Note:
Oracle recommends that you back up the OCR after you complete the node addition process.
You can now add an Oracle RAC database instance to the target node using either of the procedures in the following sections.
- Adding Policy-Managed Oracle RAC Database Instances to Target Nodes
- Adding Administrator-Managed Oracle RAC Database Instances to Target Nodes
Related Topics
Adding Policy-Managed Oracle RAC Database Instances to Target Nodes
You must manually add undo and redo logs, unless you store your policy-managed database on Oracle Automatic Storage Management (Oracle ASM) and Oracle Managed Files is enabled.
If there is space in a server pool to add a node and the database has been started at least once, then Oracle Clusterware adds the Oracle RAC database instance to the newly added node and no further action is necessary.
Note:
The database must have been started at least once before you can add the database instance to the newly added node.
If there is no space in any server pool, then the newly added node moves into the Free server pool. Use the srvctl modify srvpool command to increase the cardinality of a server pool to accommodate the newly added node, after which the node moves out of the Free server pool and into the modified server pool, and Oracle Clusterware adds the Oracle RAC database instance to the node.
                     
Adding Administrator-Managed Oracle RAC Database Instances to Target Nodes
Note:
The procedures in this section only apply to administrator-managed databases. Policy-managed databases use nodes when the nodes are available in the database’s server pool.
You can use either Oracle Enterprise Manager or DBCA to add Oracle RAC database instances to the target nodes.
This section describes using DBCA to add Oracle RAC database instances.
These tools guide you through the following tasks:
- 
                           Creating a new database instance on each target node 
- 
                           Creating and configuring high availability components 
- 
                           Creating the Oracle Net configuration for a non-default listener from the Oracle home 
- 
                           Starting the new instance 
- 
                           Creating and starting services if you entered services information on the Services Configuration page 
After adding the instances to the target nodes, you should perform any necessary service configuration procedures, as described in "Workload Management with Dynamic Database Services".
- Using DBCA in Interactive Mode to Add Database Instances to Target Nodes
- Using DBCA in Silent Mode to Add Database Instances to Target Nodes
 You can use DBCA in silent mode to add instances to nodes on which you have extended an Oracle Clusterware home and an Oracle Database home.
Related Topics
Using DBCA in Interactive Mode to Add Database Instances to Target Nodes
To add a database instance to a target node with DBCA in interactive mode, perform the following steps:
- 
                              Ensure that your existing nodes have the $ORACLE_HOMEenvironment variable set to the Oracle RAC home.
- 
                              Start DBCA by entering dbcaat the system prompt from theOracle_home/bindirectory.DBCA performs certain CVU checks while running. However, you can also run CVU from the command line to perform various verifications. DBCA displays the Welcome page for Oracle RAC. Click Help on any DBCA page for additional information. 
- 
                              Select Instance Management, click Next, and DBCA displays the Instance Management page. 
- 
                              Select Add Instance and click Next. DBCA displays the List of Cluster Databases page that shows the databases and their current status, such as ACTIVEorINACTIVE.
- 
                              From the List of Cluster Databases page, select the active Oracle RAC database to which you want to add an instance. Click Next and DBCA displays the List of Cluster Database Instances page showing the names of the existing instances for the Oracle RAC database that you selected. 
- 
                              Click Next to add a new instance and DBCA displays the Adding an Instance page. 
- 
                              On the Adding an Instance page, enter the instance name in the field at the top of this page if the instance name that DBCA provides does not match your existing instance naming scheme. 
- 
                              Review the information on the Summary dialog and click OK or click Cancel to end the instance addition operation. DBCA displays a progress dialog showing DBCA performing the instance addition operation. 
- 
                              After you terminate your DBCA session, run the following command to verify the administrative privileges on the target node and obtain detailed information about these privileges where node_listconsists of the names of the nodes on which you added database instances:cluvfy comp admprv -o db_config -d Oracle_home -n node_list [-verbose]
- 
                              Perform any necessary service configuration procedures, as described in "Workload Management with Dynamic Database Services". 
Using DBCA in Silent Mode to Add Database Instances to Target Nodes
You can use DBCA in silent mode to add instances to nodes on which you have extended an Oracle Clusterware home and an Oracle Database home.
Before you run the dbca command, ensure that you have set the ORACLE_HOME environment variable correctly on the existing nodes. Run DBCA, supplying values for the variables using the following syntax:
                        
dbca -silent -addInstance -nodeName node_name -gdbName gdb_name
  [-instanceName instance_name -sysDBAUserName sysdba -sysDBAPassword
  password]The following table describes the values that you need to supply for each variable.
Table 11-1 Variables in the DBCA Silent Mode Syntax
| Variable | Description | 
|---|---|
| node_name | The node on which you want to add (or delete) the instance. | 
| gdb_name | Global database name. | 
| instance_name | Name of the instance. Provide an instance name only if you want to override the Oracle naming convention for Oracle RAC instance names. | 
| sysdba | Name of the Oracle user with  | 
| password | Password for the  | 
Perform any necessary service configuration procedures, as described in "Workload Management with Dynamic Database Services".
Deleting Oracle RAC from a Cluster Node
To remove Oracle RAC from a cluster node, you must delete the database instance and the Oracle RAC software before removing the node from the cluster.
Note:
If there are no database instances on the node you want to delete, then proceed to "Removing Oracle RAC".
This section includes the following procedures to delete nodes from clusters in an Oracle RAC environment:
- Deleting Instances from Oracle RAC Databases
 The procedures for deleting database instances are different for policy-managed and administrator-managed databases.
- Removing Oracle RAC
 This procedure removes Oracle RAC software from the node you are deleting from the cluster and updates inventories on the remaining nodes.
- Deleting Nodes from the Cluster
Related Topics
Deleting Instances from Oracle RAC Databases
The procedures for deleting database instances are different for policy-managed and administrator-managed databases.
Deleting a policy-managed database instance involves reducing the number of servers in the server pool in which the database instance resides. Deleting an administrator-managed database instance involves using DBCA to delete the database instance.
Deleting Policy-Managed Databases
To delete a policy-managed database, reduce the number of servers in the server pool in which a database instance resides by relocating the server on which the database instance resides to another server pool. This effectively removes the instance without having to remove the Oracle RAC software from the node or the node from the cluster.
For example, you can delete a policy-managed database by running the following commands on any node in the cluster:
$ srvctl stop instance -db db_unique_name -node node_name
$ srvctl relocate server -servers "server_name_list" -serverpool FreeThe first command stops the database instance on a particular node and the second command moves the node out of its current server pool and into the Free server pool.
Deleting Instances from Administrator-Managed Databases
Note:
Before deleting an instance from an Oracle RAC database using SRVCTL to do the following:
- 
                                 If you have services configured, then relocate the services 
- 
                                 Modify the services so that each service can run on one of the remaining instances 
- 
                                 Ensure that the instance to be removed from an administrator-managed database is neither a preferred nor an available instance of any service 
- Using DBCA in Interactive Mode to Delete Instances from Nodes
 The procedure in this section explains how to use DBCA in interactive mode to delete an instance from an Oracle RAC database.
- Using DBCA in Silent Mode to Delete Instances from Nodes
Related Topics
Parent topic: Deleting Oracle RAC from a Cluster Node
Using DBCA in Interactive Mode to Delete Instances from Nodes
The procedure in this section explains how to use DBCA in interactive mode to delete an instance from an Oracle RAC database.
To delete an instance using DBCA in interactive mode, perform the following steps:
- 
                              Start DBCA. Start DBCA on a node other than the node that hosts the instance that you want to delete. The database and the instance that you plan to delete should be running during this step. 
- 
                              On the DBCA Operations page, select Instance Management and click Next. DBCA displays the Instance Management page. 
- 
                              On the DBCA Instance Management page, select the instance to be deleted, select Delete Instance, and click Next. 
- 
                              On the List of Cluster Databases page, select the Oracle RAC database from which to delete the instance, as follows: - 
                                    On the List of Cluster Database Instances page, DBCA displays the instances that are associated with the Oracle RAC database that you selected and the status of each instance. Select the cluster database from which you will delete the instance. 
- 
                                    Click OK on the Confirmation dialog to proceed to delete the instance. DBCA displays a progress dialog showing that DBCA is deleting the instance. During this operation, DBCA removes the instance and the instance's Oracle Net configuration. Click No and exit DBCA or click Yes to perform another operation. If you click Yes, then DBCA displays the Operations page. 
 
- 
                                    
- 
                              Verify that the dropped instance's redo thread has been removed by using SQL*Plus on an existing node to query the GV$LOGview. If the redo thread is not disabled, then disable the thread. For example:SQL> ALTER DATABASE DISABLE THREAD 2;
- 
                              Verify that the instance has been removed from OCR by running the following command, where db_unique_nameis the database unique name for your Oracle RAC database:$ srvctl config database -db db_unique_name
- 
                              If you are deleting more than one node, then repeat these steps to delete the instances from all the nodes that you are going to delete. 
Parent topic: Deleting Instances from Oracle RAC Databases
Using DBCA in Silent Mode to Delete Instances from Nodes
You can use DBCA in silent mode to delete a database instance from a node.
Run the following command, where the variables are the same as those shown in Table 11-1 for the DBCA command to add an instance. Provide a node name only if you are deleting an instance from a node other than the one on where DBCA is running as shown in the following example where password is the password: 
                        
dbca -silent -deleteInstance [-nodeList node_name] -gdbName gdb_name
-instanceName instance_name [-sysDBAUserName sysdba -sysDBAPassword password]At this point, you have accomplished the following:
- 
                              Deregistered the selected instance from its associated Oracle Net Services listeners 
- 
                              Deleted the selected database instance from the instance's configured node 
- 
                              Removed the Oracle Net configuration 
- 
                              Deleted the Oracle Flexible Architecture directory structure from the instance's configured node. 
Parent topic: Deleting Instances from Oracle RAC Databases
Removing Oracle RAC
This procedure removes Oracle RAC software from the node you are deleting from the cluster and updates inventories on the remaining nodes.
- 
                           If there is a listener in the Oracle RAC home on the node you are deleting, then you must disable and stop it before deleting the Oracle RAC software. Run the following commands on any node in the cluster, specifying the name of the listener and the name of the node you are deleting: $ srvctl disable listener -l listener_name -n name_of_node_to_delete $ srvctl stop listener -l listener_name -n name_of_node_to_delete
- 
                           Deinstall the Oracle home—only if the Oracle home is not shared—from the node that you are deleting by running the following command from the Oracle_home\deinstalldirectory:deinstall -localCaution: If the Oracle home is shared, then do not run this command because it will remove the shared software. Proceed to the next step, instead. 
Parent topic: Deleting Oracle RAC from a Cluster Node
Deleting Nodes from the Cluster
After you delete the database instance and the Oracle RAC software, you can begin the process of deleting the node from the cluster. You accomplish this by running scripts on the node you want to delete to remove the Oracle Clusterware installation and then you run scripts on the remaining nodes to update the node list.
Related Topics
Parent topic: Deleting Oracle RAC from a Cluster Node