Configuration of Perfect TCPIP and SQLNet
Configuration of Perfect TCPIP and SQLNet
Configuration of Perfect TCPIP and SQLNet
• Configuration of perfect TCP/IP and SQL*Net to get absolute stable Oracle Real
Application Clusters
This is a brief overview about everything required to get a stable RAC network
environment.
For more details read Oracle Note:151972.1, Note:249213.1 , Note:1019963.102
This document shows my experiences with Dead Connection Detection. My
recommendation is to implement Oracle Note 249213.1 to get a real working Dead
Connection Detection and Transparent Applictation Failover not using TAF
(How_to_configure_TAF).
The configuration below is excellent in a RAC environment using active/passive node on
a RAC. For example you have a two node RAC and only one node is active and the other
is a 'Hot Standby' node than this configuration will allow a fast switchover to the second
node in case of failure of the first one.
Installation
• This article describes a complete overview about what to do to get stable
networking.
Usage
• Implement the given configuration steps as required by your operating systems
• Do a test if there are firewalls between your Oracle Real Application Cluster and
the Client Software
Recommendations
• Always implement changes in a production environment after having some test in
a lab.
The usage of "enable=broken" and the necessary changes of the IP stack are well tested.
In normal situations a system do not need these settings because in most cases Oracle's
PMON will detect a lost session and also the client will detect itself that a session was
closed unexpected.
Settings described here are for rare cases which the normal settings do not solve
sufficient.
Settings recommended here are just recommended to have always the planned behaviour.
Example(s)
Real Application Cluster on an AIX 5.3 site and OCI clients on a Windows 2003
server site
Configurations steps on the RAC in sqlnet.ora
AIX TCP_KEEPIDLE
Description: This determines the length of inactivity before keepalive
messages are sent
and ensuring how long a connection stays in an active/ESTABLISHED state.
Default value: 14400 (in half seconds, which is 2 hours)
TCP_KEEPINTVL
Description: Specifies how often these keepalive probe messages are
sent.
The connection is considered broken after 8 unresponded probes.
Default value: 150 (in half seconds which is 75 seconds)
TCP_KEEPINIT
Description: Specifies the initial timeout value for TCP connections.
Default value: 150 (in half seconds which is 75 seconds)
To check the current setting, type "no -a", to change the settings.
So, as root, issue "no -o <option>=<value>", e.g.:
no -o tcp_keepidle=1200
no -o tcp_keepintvl=40
• Linux TCP parameters
net.ipv4.tcp_keepalive_time 3000
net.ipv4.tcp_retries2 5
net.ipv4.tcp_syn_retries 1