我正在尝试使用ODP.NET版本2.111.6.20为我的.NET应用程序配置连接池。数据库是Oracle 11.1。ODP.NET连接池参数
我用我的.NET 2.0的应用程序下面的连接字符串:
Data Source=prod; User Id=FAKE_USER; Password=FAKE_PASS; Pooling=true; Min Pool Size=2; Max Pool Size=5; Connection Timeout=30;"
根据文档的连接池应该有2个连接和初始化,并根据需要增加多达5个连接。它永远不会超过5个连接。
我所看到的是连接正在增长,一次增长到10个连接。我通过查询v $ session表来监视Oracle数据库中的连接,所以我知道连接来自于源自我的应用程序的特定应用程序。
如果任何人都可以帮助我确定此应用程序中的连接池中可能发生了什么,可能会允许超过最大连接数,我将不胜感激。
样品C#代码
这里是使数据库的调用的代码示例:
const string connectionString = "Data Source=prod; User Id=FAKE_USER; Password=FAKE_PASS; Pooling=true; Min Pool Size=5; Max Pool Size=5; Connection Timeout=30;";
using (OracleConnection connection = new OracleConnection(connectionString)) {
connection.Open();
using (OracleCommand command = new OracleCommand("ALTER SESSION SET TIME_ZONE='UTC'", connection)) {
command.ExecuteScalar();
}
using (OracleTransaction transaction = connection.BeginTransaction()) {
const string procSql = @"BEGIN P_SERVICES.UPDATE_VERSION(:id, :version, :installDate); END;";
using (OracleCommand command = new OracleCommand(procSql, connection)) {
command.Parameters.Add(new OracleParameter("id", OracleDbType.Varchar2) { Value = id });
command.Parameters.Add(new OracleParameter("version", OracleDbType.Varchar2) { Value = version });
command.Parameters.Add(new OracleParameter("installDate", OracleDbType.TimeStamp) { Value = dateUpdated });
try {
command.ExecuteNonQuery();
} catch (OracleException oe) {
if (Log.IsErrorEnabled) {
Log.ErrorFormat("Update Error: {0}", oe.Message);
}
throw;
}
transaction.Commit();
}
}
}
你可以发表你如何执行你的命令的例子吗?很高兴看到您使用的是“USING”还是手动创建/处理您的连接/命令 –
请参阅代码示例原始文章的更新...如您所见,我已在使用语句代码而不是手动关闭处理连接 – jprincipe
My Oracle.DataAccess程序集是4.112.3.0,是否您的程序集版本为2.111.6.20?如果是这样,也许是时候更新了。除非你被限制在.NET 4以前版本,并且不能? –