Я новичок в Oracle и столкнулся с проблемой.Когда я запускаю приложение из IDE - Visual Studio 2005, соединение с базой данных устанавливается гладко, но когда я запускаю установленную версию приложения, соединение с БД не удается, и я получаю сообщение об ошибке TNS: Соединение истекло.
Я пытался использовать SQLNET.ORA и аналогичные решения, найденные в Интернете, но не смог решить проблему.Интересно, почему это происходит, поскольку приложение, работающее через IDE и через установку, находится на одном компьютере.Я убедился, что файл TNSNAMES.ORA правильно отредактирован, и я могу подключиться через экземпляр приложения, работающего непосредственно в Visual Studio.
public bool connectToDatabase(string dbConnStr)
{
try
{
databaseConnection = dbConnStr;
OracleConnection dbConn = new OracleConnection(databaseConnection);
if (dbConn == null)
{
CreateDLLLogFiles.ErrorLog(CreateDLLLogFiles.FileName, "Connection object is null");
return false;
}
if (dbConn.State.ToString().Equals("Closed", StringComparison.OrdinalIgnoreCase))
{
CreateDLLLogFiles.ErrorLog(CreateDLLLogFiles.FileName, "DB connection - " + dbConn.ConnectionString);
dbConn.Open();
return true;
}
}
catch (Exception ex)
{
CreateDLLLogFiles.ErrorLog(CreateDLLLogFiles.FileName, ex.Message + "\n" + ex.StackTrace);
CreateDLLLogFiles.ErrorLog(CreateDLLLogFiles.FileName, "DB String - " + databaseConnection);
return false;
}
return false;
}
Трассировка стека выглядит следующим образом:
7/22/2010 6:38:51 PM ORA-12170: TNS:Connect timeout occurred
at Oracle.DataAccess.Client.OracleException.HandleErrorHelper(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, String procedure, Boolean bCheck)
at Oracle.DataAccess.Client.OracleException.HandleError(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, Object src)
at Oracle.DataAccess.Client.OracleConnection.Open()
at SQL.connectToDatabase(String dbConnStr)
tnsnames.ora выглядит примерно так:
MySource =
(DESCRIPTION =
(CONNECT_TIMEOUT=180)(RETRY_COUNT=2)
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 125.63.77.232)(PORT = 1521)))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = MySource )
)
)
Тем временем мне выдавалась ошибка ContextSwitchDeadlock через отладчик, поэтому я следовал инструкциям и изменил атрибут с STAThread на MTAThread на Main().Больше нет ContextSwitchDeadlock - и все же проблема с подключением сохраняется.
Я надеялся, что вы сможете пролить свет на этот вопрос - я близок к тому, чтобы вырвать свои волосы.Любое понимание будет оценено.