This chapter describes the procedures for configuring server migration for an enterprise deployment.
This chapter includes the following sections:
Section 17.1, "Overview of Server Migration for an Enterprise Deployment"
Section 17.2, "Setting Up a User and Tablespace for the Server Migration leasing Table"
Section 17.3, "Creating a GridLink Data Source for leasing Using the Administration Console"
Section 17.5, "Setting Environment and Superuser Privileges for the wlsifconfig.sh Script"
You can configure server migration for Oracle WebLogic Server Managed Servers. With server migration configured, should failure occur, each Managed Server can restart on a different host machine. The Managed Servers listen on specific floating IP addresses that are failed over by WebLogic Server.
Note:
Refer to each component's chapter for details on whether it uses or requires server migration or not.The procedures described in this chapter must be performed for various components of the enterprise deployment topology outlined in Section 1.1.1, "Reference Topology Documented in This Guide."
Variables are used in this chapter to distinguish between component-specific items:
WLS_SERVER1 and WLS_SERVER2 refer to the WebLogic Server Managed Servers for the enterprise deployment component.
HOST1 and HOST2 refer to the host machines for the enterprise deployment component.
CLUSTER refers to the cluster associated with the enterprise deployment component.
The values to be used for these variables are provided in the component-specific chapters in this EDG.
In this enterprise topology, you must configure server migration for the WLS_SERVER1 and WLS_SERVER2 Managed Servers. The WLS_SERVER1 Managed Server is configured to restart on HOST2 should a failure occur. The WLS_SERVER2 Managed Server is configured to restart on HOST1 should a failure occur. For this configuration, the WLS_SERVER1 and WLS_SERVER2 servers listen on specific floating IP addresses that are failed over by WebLogic Server migration.
Table 17-1 describes the steps for configuring server migration for the WebLogic Server Managed Servers.
Table 17-1 Steps for Configuring Server Migration
| Step | Description | More Information | 
|---|---|---|
| Set up a user, tablespace, and migration table | Create a  | Section 17.2, "Setting Up a User and Tablespace for the Server Migration leasing Table" | 
| Create GridLink data sources for the  | Create a data source for each of the Oracle RAC database instances and the global  | Section 17.3, "Creating a GridLink Data Source for leasing Using the Administration Console" | 
| Specify Node Manager properties values for migration | Edit the property values in the  | |
| Set the environment and specify superuser privileges for the oracle user | Add files to the  | Section 17.5, "Setting Environment and Superuser Privileges for the wlsifconfig.sh Script" | 
| Configure cluster migration | Assign available nodes as migration targets, and specify candidate machines for each server. | |
| Test server migration | Verify server migration between hosts from Node Manager or the Administration Console. | 
Set up a user and tablespace for the server migration leasing table using the create tablespace leasing command.
Note:
If other servers in the same domain have already been configured for server migration, you can use the same tablespace and data sources. In that case, the data sources and GridLink data source for the database tableleasing do not need to be re-created, but they will have to be retargeted to the cluster being configured with server migration.To set up a user and tablespace for the server migration leasing table:
Create a tablespace called leasing. For example, log in to SQL*Plus as the sysdba user and run the following command:
SQL> create tablespace leasing
        logging datafile 'DB_HOME/oradata/orcl/leasing.dbf'
        size 32m autoextend on next 32m maxsize 2048m extent management local;
Note:
The database file location will vary depending on the type of storage and data file location used for the database.Create a user named leasing, and assign to it the leasing tablespace:
SQL> create user leasing identified by password;
SQL> grant create table to leasing;
SQL> grant create session to leasing;
SQL> alter user leasing default tablespace leasing;
SQL> alter user leasing quota unlimited on leasing;
Create the leasing table using the leasing.ddl script:
Copy the leasing.ddl file located in either of the following directories to your database node:
WL_HOME/server/db/oracle/817/ WL_HOME/server/db/oracle/920/
Connect to the database as the leasing user.
Run the leasing.ddl script in SQL*Plus:
SQL> @copy_location/leasing.ddl;
Commit the changes in the database
SQL> commit;
Create a GridLink data source for the leasing table from the Oracle WebLogic Server Administration Console.
To create a GridLink data source:
Log in to the WebLogic Server Administration Console.
If you have not already done so, in the Change Center, click Lock & Edit and click Next.
In the Domain Structure tree, expand Services, then select Data Sources.
On the Summary of Data Sources page, click New, select GridLink Data Source, and perform the following steps:
Enter a logical name for the data source in the Name field. For example, leasing.
Enter a name for JNDI. For example, jdbc/leasing.
For the Database Driver, select Oracle's Driver (Thin) for GridLink Connections; Versions: 11 and later.
Click Next.
On the Transaction Options screen, clear Supports Global Transactions, and click Next.
On the GridLink Data Source Connection Properties Options screen, select Enter individual listener information, and click Next.
Enter the following connection properties:
Service Name: Enter the service name of the database with lowercase characters. For a GridLink data source, you must enter the Oracle RAC service name. For example:
wccedg.example.com
Host Name and Port: Enter the SCAN address and port for the RAC database being used, and click Add. You can identify this address by querying the appropriate parameter in the database using the TCP Protocol:
SQL>show parameter remote_listener; NAME TYPE VALUE -------------------------------------------------- remote_listener string db-scan.example.com
Note:
For Oracle Database 11g, use the virtual IP address and port of each database instance listener, as in these examples:wccdbhost1-vip.example.com (port 1521) wccdbhost2-vip.example.com (1521)
Database User Name: leasing
Password: Enter the password for the leasing user.
Confirm Password: Enter the password again and click Next.
On the Test GridLink Database Connection page, review the connection parameters and click Test All Listeners. Here is an example of a successful connection notification:
Connection test for jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=db-scan.example.com) (PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=wccedg.example.com))) succeeded.
Click Next.
In the ONS Client Configuration page, perform the following steps:
Select FAN Enabled to subscribe to and process Oracle FAN events.
Enter the host names for the RAC database and the ONS remote port, as reported by the database, and click ADD:
The following example displays the number of the ONS remote port:
[orcl@db-scan1 ~]$ srvctl config nodeapps -s ONS exists: Local port 6100, remote port 6200, EM port 2016
Click Next.
Note:
For Oracle Database 11g, use the host name and port of each database's ONS service, as in these examples:wccdbhost1.example.com (port 6200) wccdbhost2.example.com (6200)
On the Test ONS Client Configuration s, review the connection parameters, and click Test All ONS Nodes.
Here is an example of a successful connection notification:
Connection test for db-scan.example.com:6200 succeeded.
Click Next.
In the Select Targets page, select the targets for which you are doing server migration, IMG_Cluster, CPT_Cluster, SOA_Cluster, and All Servers in the cluster.
Click Finish.
Click Activate Changes.
The third step is to edit the Node Manager properties file. This needs to be done for Node Manager in both nodes where server migration is being configured:
Interface=eth0 NetMask=255.255.255.0 UseMACBroadcast=true
Interface: This property specifies the interface name for the floating IP address (for example, eth0).
Do not specify the subinterface, such as eth0:1 or eth0:2. This interface is to be used without :0 or :1. The Node Manager scripts traverse the different :X-enabled IP addresses to determine which to add or remove. For example, the valid values in Linux environments are eth0, eth1, eth2, eth3, and ethn, depending on the number of interfaces configured.
NetMask: This property specifies the net mask for the interface for the floating IP address. The net mask should the same as the net mask on the interface; 255.255.255.0 is used as an example in this document.
UseMACBroadcast: This property specifies whether or not to use a node's MAC address when sending ARP packets, that is, whether or not to use the -b flag in the arping command.
Verify in the Node Manager output (shell where Node Manager is started) that these properties are being used, or problems might arise during migration. You should see something like this in Node Manager's output:
... StateCheckInterval=500 Interface=eth0 NetMask=255.255.255.0 ...
Note:
The following step is not required if the server properties (start properties) have been properly set and Node Manager can start the servers remotely.Set the following property in the nodemanager.properties file:
StartScriptEnabled: Set this property to true. This is required for Node Manager to start the Managed Servers using start scripts.
Note:
When you run Node Manager from a shared storage installation, multiple nodes are started using the samenodemanager.properties file. Each node, however, may require different NetMask or Interface properties. In this case, specify individual properties on a per-node basis using environment variables. For example, to use a different interface (eth3) in HOSTn, use the Interface environment variable as follows:export JAVA_OPTIONS=-DInterface=eth3For each node, you can include other Java options that specify properties to pass to Node Manager. For example, for WCCHOST1, which hosts the Administration Server, include -DDomainRegistrationEnabled= along with -DCustomIdentityAlias= in the JAVA_OPTIONS parameter.
The fourth step is to set environment and superuser privileges for the wlsifconfig.sh script (for the oracle user):
To set environment and superuser privileges for the script:
Ensure that your PATH environment variable includes the files listed in Table 17-2.
Grant the sudo privilege for the wlsifconfig.sh script.
Configure sudo to work without a password prompt.
For security reasons, sudo should be restricted to the subset of commands required to run the wlsifconfig.sh script. For example, perform these steps to set the environment and superuser privileges for the wlsifconfig.sh script:
Grant the sudo privilege to the WebLogic Server user (oracle) with no password restriction, and grant execute privilege on the /sbin/ifconfig and /sbin/arping binaries.
Make sure the script is executable by the WebLogic Server user (oracle). The following is an example of an entry inside /etc/sudoers granting the sudo execution privilege for oracle and also over ifconfig and arping:
oracle ALL=NOPASSWD: /sbin/ifconfig,/sbin/arping
Note:
Ask the system administrator for thesudo and system privileges as appropriate for this step.Start Node Manager on HOST1 and HOST2 by running the startNodeManager.sh script, which is located in the WL_HOME/server/bin/ directory:
nohup ./startNodeManager.sh > nm.out&
The fifth step is to configure server migration targets. You first assign all the available nodes for the cluster's members and then specify candidate machines (in order of preference) for each server that is configured with server migration.
To configure cluster migration in a migration in a cluster:
Log in to the WebLogic Server Administration Console (http//ADMINVHN:7001/console).
In the Domain Structure tree on the left, expand Environment and select Clusters.
On the Summary of Clusters page, click the cluster for which you want to configure migration (CLUSTER) in the Name column of the table.
Note:
For the procedures in this document, configure server migration for the Imaging, Capture, and Oracle SOA Suite clusters.Open the Migration tab.
Click Lock & Edit.
In the Available field, select the machine to which to allow migration and click the right arrow. In this case, select HOST1 and HOST2.
Select the data source to be used for automatic migration. In this case, select the leasing data source.
Click Save.
Click Activate Changes.
Click Lock & Edit.
Set the candidate machines for server migration. You must perform this task for all of the Managed Servers, as follows:
In the Domain Structure tree on the left of the WebLogic Server Administration Console, expand Environment and select Servers.
Select the server for which you want to configure migration.
Note:
For the procedures in this document, configure server migration for the Imaging, Capture, and Oracle SOA Suite clusters.Open the Migration tab.
In the Available field, located in the Migration Configuration section, select the machines to which to allow migration and click the right arrow. For WLS_SERVER1, select HOST2. For WLS_SERVER2, select HOST1.
Select Automatic Server Migration Enabled. This enables Node Manager to start a failed server on the target node automatically.
Click Save.
Click Activate Changes.
Restart Node Manager, the Administration Server, and the servers for which server migration has been configured:
First, stop the Managed Servers through the Administration Console.
Then restart the Node Manager and Administration Server, as described in step 11 under Section 8.4.5, "Disabling Host Name Verification,"
Finally, start the Managed Servers again, through the Administration Console.
The sixth and final step is to test the server migration.
To verify that server migration is working properly from HOST1:
Stop the WLS_SERVER1 Managed Server. To do this, run this command on HOST1:
kill -9 pid
where pid specifies the process ID of the Managed Server. You can identify the process ID in the node by running this command:
ps -ef | grep WLS_SERVER1
Watch the Node Manager console. You should see a message indicating that WLS_SERVER1's floating IP address has been disabled.
Wait for Node Manager to try a second restart of WLS_SERVER1. It waits for a fence period of 30 seconds before trying this restart.
Once Node Manager restarts the server, stop it again. Node Manager should now log a message indicating that the server will not be restarted again locally.
To verify that server migration is working properly from HOST2:
Watch the local Node Manager console. After 30 seconds since the last try to restart WLS_SERVER1 on node 1, Node Manager on node 2 should prompt that the floating IP address for WLS_SERVER1 is being brought up and that the server is being restarted in this node.
Access your server's console in the same IP address.
To verify that server migration is working properly from the Administration Console
Log in to the Administration Console.
Click Domain on the left.
Click the Monitoring tab and then the Migration subtab.
The Migration Status table provides information on the status of the migration (Figure 17-1).
Figure 17-1 Migration Status Screen in the Administration Console

Note:
After a server is migrated, to fail it back to its original node or machine, stop the Managed Server from the WebLogic Server Administration Console and then start it again. The appropriate Node Manager will start the Managed Server on the machine to which it was originally assigned.