oracle 侦听器拒绝连接并出现以下错误:ORA-12505,TNS:侦听器当前不知道连接描述符中给出的 SID

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/34061799/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-09-19 03:06:15  来源:igfitidea点击:

Listener refused the connection with the following error: ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

oracletns

提问by ?ukasz

I had my database working for over a year since yesterday. Out of sudden, I am no longer able to connect.

从昨天开始,我的数据库已经工作了一年多。突然之间,我无法再连接了。

enter image description here

在此处输入图片说明

Error I am getting is:

我得到的错误是:

Status : Failure -Test failed: Listener refused the connection with the following error:
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

Oracle 11.2 Windows 7

甲骨文 11.2 视窗 7

Both db and the listener are up and running. Port 1521 is opened.

db 和侦听器都已启动并正在运行。端口 1521 已打开。

C:\Apps\Oracle\product.2.0\dbhome_1\BIN>netstat -a -n -o| findstr "1521"
  TCP    127.0.0.1:1521         0.0.0.0:0              LISTENING       2412

trying to log in via sqlplus

尝试通过 sqlplus 登录

C:\depot\SBApp\main>sqlplus sbdba0/sbdba0@SBDB

SQL*Plus: Release 11.2.0.2.0 Production on Thu Dec 3 10:04:29 2015

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

Error:

错误:

ORA-12514: TNS:listener does not currently know of service requested in connect descriptor 
ORA-12514: TNS:listener does not currently know of service requested in connect descriptor 

Listener.ora

监听器.ora

# listener.ora Network Configuration File: C:\Apps\Oracle\product.2.0\dbhome_1\NETWORK\ADMIN\listener.ora
# Generated by Oracle configuration tools.

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = CLRExtProc)
      (ORACLE_HOME = C:\Apps\Oracle\product.2.0\dbhome_1)
      (PROGRAM = extproc)
      (ENVS = "EXTPROC_DLLS=ONLY:C:\Apps\Oracle\product.2.0\dbhome_1\bin\oraclr11.dll")
    )
  )

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    )
  )

ADR_BASE_LISTENER = C:\Apps\Oracle\product

tnsnames.ora

tnsnames.ora

ORACLR_CONNECTION_DATA =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
    (CONNECT_DATA =
      (SID = CLRExtProc)
      (PRESENTATION = RO)
    )
  )

###################################################################################################
#SBDB
SBDB =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = SBDB)
    )
  )

ifile=C:\Apps\Oracle\product.2.0\dbhome_1\NETWORK\ADMIN\tnsnames_QA.ora

ifile=C:\Apps\Oracle\product.2.0\dbhome_1\NETWORK\ADMIN\tnsnames_PROD.ora

I am out of ideas, any help will be appreciated.

我没有想法,任何帮助将不胜感激。

采纳答案by ?ukasz

solved,

解决了,

had to replace localhost from *.ora files with my PC hostname.

必须用我的 PC 主机名替换 *.ora 文件中的 localhost。