Here’s the scenario…
We have an internal website that is running the latest version of the ODAC (Oracle Client). It opens database connections, runs a stored procedure or packaged method, then disconnects. Connection pooling is turned on, and we are currently under version 11g in both our development and test environments, but under 10gR2 in our production environment. This happens on Production.
A few days ago, a process began firing off a ORA-2020 error. The process is called from a webpage on our internal website. The user simply sets a date, hits a button, and a job is started on another system that is separate from the website. The call itself, however, uses a database link to run a function.
We’ve scoured the SQL to find that it only uses that one database link. And since these links are on a per session basis and the user isn’t exceeding the default limit of 4, how is it possible that we are getting a ORA-2020 error.
We have ran a number of tests to try to push over the default limit of 4. ODAC, from what I recall, runs a commit after each connection, and I can’t seem to run 4 DB links, then run a piece of SQL with 1 DB link directly after with any errors. The only way I can bring up this error is if I run a query with 4 DB links, then a function or piece of dynamic SQL with a database link within it. We don’t have that problem as this issue is sporadic. It isn’t ALWAYS happening.
Questions
- Is it possible that connection pooling is allowing User B to use User A’s connection after the initial process was run, thus adding to the open links number if User B runs a SQL statement with more database links?
- Is this a scenario where we should up our limit past 4? What are the disadvantages of increasing the number?
- Do I need to explicitly close open database links before disconnecting from the database? Oracle documentation seems to suggest it should automatically happen, but “on occasion”… doesn’t.
We ended up increasing the link amount, but we never did find the root cause.