Details of error are as follows.
ORA-00609: could not attach to incoming connection
ORA-12537: TNS:connection closed
ORA-609 : opiodr aborting process unknown ospid (2436_7464)
ORA-609 : opiodr aborting process unknown ospid (21631120_1)
Opiodr aborting process unknown ospid
When a client makes a connection with Oracle Database, there are multiple steps involved.
These steps do multiple network trips between the client and the server.
The parameters that we are using here are basically hiding a problem in the network from the application .
These parameters control when Oracle will throw an error about connections not getting completed.
Please do ask your network team to look into network issues.
This ORA-609 errors are related with the client disconnecting before the connection can be established fully. Timeout parameters INBOUND_CONNECT_TIMEOUT_<listener_name> in the LISTENER.ORA file and SQLNET.INBOUND_CONNECT_TIMEOUT in the SQLNET.ORA need to be reviewed.
If using the default of 60 seconds, (no explicit setting), then it is likely these parameters will need to be increased.
- Review and check network settings for the server machine where the database is running. Ensure settings are all correct and as expected and DNS servers are available
- If the server platform is Microsoft Windows, check the Windows Services for TNS listener and database ensure each service is started using the same account.
ORA-609 with TNS-12537: TNS:connection closed
We almost time receive an error such as ora-609 which shows in alert log as
TNS- TNS-12537: TNS:connection closed
ns secondary err code: 12560
nt main err code: 0
nt secondary err code: 0
nt OS err code: 0
opiodr aborting process unknown ospid (12345) as a result of ORA-609
This error means could not attach to incoming connection, so our database process was aborted or closed because incoming connection was not passed to it by listener. In our case we found sqlnet error stack as shown below
TNS-12537: TNS:connection closed
As we all know the process of client connections:
1. First Client initiates a connection to the database so it connects to the listener.
2. Then listener starts a dedicated DB process that will receive this connection or session.
3. After that, this dedicate process is started and listener passes the connection from the client to this process.
4. Then the sever process takes the connection from the listener to continue the handshake with the client.
5. After that Server process and client exchange messages or information required for establishing a session or user logon.
In our case, it may be when the dedicated process tries to communicate with the client it finds that connection was closed.
đŸ‘‰Solution or Work around:
We can eliminate this error by increasing the value of SQLNET.INBOUND_CONNECT_TIMEOUT in sqlnet.ora file.
By default the SQLNET.INBOUND_CONNECT_TIMEOUT value is 60 seconds.
The sqlnet.ora file can be found in RDBMS_HOME/network/admin.
For example:
$ cd $ORACLE_HOME/network/admin
$vi sqlnet.ora
And change the value of SQLNET.INBOUND_CONNECT_TIMEOUT as:
SQLNET.INBOUND_CONNECT_TIMEOUT=120
SQLNET.EXPIRE_TIME = 15
Then save the file.
There are many more possibilities which can cause this error such as:
1. This can happen suppose our client closed the connection immediately after initiating it.
2. This may occur when firewall kill the connection.
3. Sometimes, it may happen because of Database, OS or network performance problem.
4. This error may occur when some client crashes.
To solve this error,
set SQLNET.INBOUND_CONNECT_TIMEOUT=180 in Sqlnet.ora.
and set INBOUND_CONNECT_TIMEOUT_listener_name=120 in Listener.ora
under
$ORACLE_HOME/network/admin.
No comments:
Post a Comment