oracle ora-12154问题总结

oracle ora-12154问题总结在使用oracle时,经常会遇到ora-12154问题,但一直没总结,解决办法过段时间就忘,再遇到问题只能再去找解决办法。今天,把目前了解到的内容汇总记录,方便以后查找。

大家好,又见面了,我是你们的朋友全栈君。

在使用oracle时,经常会遇到ora-12154问题,但一直没总结,解决办法过段时间就忘,再遇到问题只能再去找解决办法。今天,把目前了解到的内容汇总记录,方便以后查找。

一、监听器介绍

1、概念   

        监听器直接面向用户,也就是客户端程序。监听器启动时,负责打开监听端口,等待客户端连接。当有客户端连接时,在专用服务器连接模式下,创建专用服务器进程,用来处理和响应用户请求;而在共享服务器连接模式下,将监听到的用户请求转发调度器,再由调试器调度共享服务器进程处理。以前一直以为oracle服务器中一个实例对应一个监听器,最近才刚知道oracle服务器可以创建多个数据库实例,这多个实例可以使用同一个监听器。这样一来,数据库实例进程只负责维护管理数据库,并不参与和客户端的通信。

 2、listener.ora文件

        监听器在服务器中对应的配置文件叫listener.ora,在…\dbhome\network\admin\目录下,格式如下。SID_LIST_LISTENER表示名为LISTENER的监听器内注册的实例列表,里面包含所注册的实例信息,全局名称和sid名称;LISTENER表示监听器,里面包含该监听器所支持的协议及地址。监听器创建可以直接修改listener.ora文件,也可以通过oracle自带的配置工具创建。给监听器注册实例可以通过修改该文件静态注册,也可以动态注册(可查看相关资料)。

SID_LIST_LISTENER =  #监听器LISTENER服务的实例列表
  (SID_LIST =  
    (SID_DESC =      #实例1
      (SID_NAME = CLRExtProc)  
      (ORACLE_HOME = C:\app\root\product\11.2.0\dbhome_1)  
      (PROGRAM = extproc)  
      (ENVS = "EXTPROC_DLLS=ONLY:C:\app\root\product\11.2.0\dbhome_1\bin\oraclr11.dll")
    )  
    (SID_DESC =      #实例2
      (GLOBAL_DBNAME = orcl)  
      (ORACLE_HOME = C:\app\root\product\11.2.0\dbhome_1)  
      (SID_NAME = orcl)  
    )  
  )  
LISTENER =           #监听器LISTENER
  (DESCRIPTION_LIST =  
    (DESCRIPTION =  
      (ADDRESS_LIST =  # 监听器协议及地址
        (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))  
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))  
      )  
    )  
  )

SID_LIST_LISTENER2 =  #监听器LISTENER2服务的实例列表
  (SID_LIST =  
    (SID_DESC =      #实例1
      (SID_NAME = CLRExtProc)  
      (ORACLE_HOME = C:\app\root\product\11.2.0\dbhome_1)  
      (PROGRAM = extproc)  
      (ENVS = "EXTPROC_DLLS=ONLY:C:\app\root\product\11.2.0\dbhome_1\bin\oraclr11.dll")
    )  
    (SID_DESC =      #实例2
      (GLOBAL_DBNAME = orcl2)  
      (ORACLE_HOME = C:\app\root\product\11.2.0\dbhome_1)  
      (SID_NAME = orcl2)  
    )  
  )  
LISTENER2 =           #监听器LISTENER2
  (DESCRIPTION_LIST =  
    (DESCRIPTION =  
      (ADDRESS_LIST =  # 监听器协议及地址
        (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))  
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1522))  
      )  
    )  
  )

3、监听器常用命令

         在命令行中输入lsnrctl命令,进入lsnrctl命令行,输入help可以查看支持的命令。常用的包括status,start <xxx>和stop <xxx>等。其中,status可以查看当前服务器中监听器的状态,start可以启动特定监听器,stop可以关闭特定监听器,不加参数指启动或关闭所有监听器。

二、问题原因

1、监听服务未启动,通过lsnrctl status命令查看监听服务有没启动
2、连接的数据库实例没有在监听器中注册
      检查listener.ora文件,看SID_LIST_LISTENER内有无所连接的实例。如果没有,补上。
3、监听器的IP配置为localhost
      在oracle服务器端,检查tnsnames.ora和listener.ora文件(一般情况下oracle服务器不需要tnsnames.ora文件,在多服务器做数据共享时才需要
。网上查的,未确认过),将监听器和实例中的localhost改为IP地址。
      在使用netmanager工具来配置时,比较容易出现这些问题。
4、tnsnames.ora和listener.ora中实例名不一致
      这种情况可能出现在为了解决12541问题,而多次删除或创建监听器导致。
在修改监听器时,最好先用lsnrctl stop命令关闭所有监听服务
5、客户端配置问题,检查客户端的tnsnames.ora文件
      这类问题是在搜索解决方法时发现的,本人并没有遇到过。症状多发生在使用plsql或其他客户端工具时,没有配置oracle主目录导致未找到tnsnames.ora文件或该文件本身有问题(文件中的实例名前不能有空格)。

附tnsnames.ora文件格式
orcl =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100 )(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )

三、解决思路

1、先确认客户端连接配置没有问题,特别是服务名。如果使用plsql之类工具,检查oracle主目录和oci路径配置是否正确;
2、检查服务器端,首先通过lsnrctl status命令查看监听服务有没启动,状态有无问题;
3、如服务已启动且状态正确,检查服务器端配置文件,包括listener.ora和tnsnames.ora;
4、修改配置文件时,要先关闭监听服务,修改完成后再打开。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161526.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月24日 下午8:46
下一篇 2022年7月24日 下午8:46


相关推荐

  • 在Vs Code中搭建JSP开发环境

    在Vs Code中搭建JSP开发环境如何在 VisualStudio 中搭建 JSP 网页的开发环境准备 VisualStudio 和 Java 开发环境 VsCode 的安装不再赘述首先需要在 vscode 中搭建好 Java 的开发环境 安装 java 环境的扩展插件下载 jdk 建议使用 jdk11 若有梯子可以上官网下载 没有的话建议去清华大学的镜像站下载下载好之后将 JDK 的环境变量配置好 配置 JDK 的环境变量网上已经有大量资料 不再赘述 特别提醒系统变量中必须要有一个叫 JAVA

    2026年3月26日
    2
  • java double 类型_关于Java中的double类型数据

    java double 类型_关于Java中的double类型数据在初学 Java 的时候 一般我们都会从基本的数据类型开始学习 而在基本数据类型中 我认为 double 类型是比较难理解的 并且在以后的学习或工作中 在 double 类型数据这遇到的坑也是极多的 例如下面的这样一个程序 publicstatic String args System out println 2 0 1 1 很多人会认为上面的程序会打印出 0 9 但实际上 它打

    2026年3月18日
    2
  • 怎么将多个ppt合并到一个ppt上_如何合并多个ppt文件

    怎么将多个ppt合并到一个ppt上_如何合并多个ppt文件在一个文件夹下面有a.ppt,b.ppt,c.ppt等PPT文件,如果把它们合并到一个新的PPT中?当PPT文件数量比较少的时候,我们还可以一个个打开,复制所有的幻灯片到新建的PPT中。当文件数量达

    2022年8月5日
    7
  • HorizontalScrollView 详解[通俗易懂]

    HorizontalScrollView 详解[通俗易懂]2019独角兽企业重金招聘Python工程师标准>>>…

    2022年7月14日
    22
  • SPI协议代码

    SPI协议代码软件模拟SPI程序代码概述:   通过两个MCU(STM32F103)来模拟SPI的主从机,完成主机发送从机接收,便于理解SPI协议。SPI协议简介●SPI接口介绍  SCK:时钟信号,由主设备产生,所以主设备SCK信号为输出模式,从设备的SCK信号为输入模式。  CS:使能信号,由主设备控制从设备,,所以主设备CS信号为输出模式,从设备的CS信号为输入模式。  MOSI:主设备数据输出,从设备数据输入,所以主设备MOSI信号为输出模式,从设备的MOSI信号为输入模式。  MISO:主设备数

    2022年10月16日
    4
  • filter pitcher是什么意思_EncodingFilter

    filter pitcher是什么意思_EncodingFilterorg.apache.struts2.dispatcher.FilterDispatcher是Struts2的主要的Filter,负责四个方面的功能:       (1)执行Actions       (2)清除ActionContext       (3)维护静态内容       (4)清除request生命周期内的XWork的interceptors   另注:该

    2022年8月16日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号