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

注开始的时候报的这个错误: ora-12545:Connection failed because target host or object does not exsit

重启主服务和监听服务后报    ora-12514:TNS:listener does not currently know of service requested in connect descriptor

 

最后通过如下方法解决:

(转)

这个错误是因为Listener出了问题,请检查一下你的listener.ora文件,看下是否存在如下配置:

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = E:/oracle/product/10.2.0/db_1)
      (PROGRAM = extproc)
    )
)

       如果说是这样,那么请将一段改成

SID_LIST_LISTENER =
 (SID_LIST =
 (SID_DESC =
  (SID_NAME = PLSExtProc)
  (ORACLE_HOME = E:/oracle/product/10.2.0/db_1)
  (PROGRAM = extproc)
  )

(SID_DESC =
     (GLOBAL_DBNAME = ORCL)
     (ORACLE_HOME = E:/oracle/product/10.2.0/db_1)
     (SID_NAME = ORCL)
  )
)

 

        黄色为服务器上没有的
         这样以后,关掉Service和LISTENER。再启动Service和LISTENER,这样应该就可以了,注意顺序

          查了一下,网上是说,加上了面一段东西,意思是把LISTENER服务主动注册到进程监视器(pmon)中去。所以,但你启动了Serivce后,启动LISTENER的时候,会主动去注册到进程监视器(pmon)中去。所以不会有什么问题。但是反过却不行。

         如果说没有添加那一段,情况正好相反,是由实例的pmon进程在LISTENER中注册服务,LISTENER为被动注册。所以需要先起LISTENER才可以。

        总结一下,如果说你不加那段东西,那么就应该先起LISTENER,如果说你加了那段东西,就应该先起Serivce。

        我试了一下,的确是这样。不过在windows上,有时候会报错,重启一下再试就可以了。

 

posted on 2013-10-15 11:42  中子持心  阅读(1181)  评论(0编辑  收藏  举报

导航