连接Oracle数据库失败(ORA-12514)故障排除
创始人
2025-01-20 14:04:01
0

文章目录

  • 症状
  • 产生原因
  • 解决办法

点击试看博主的专著《MySQL 8.0运维与优化》(清华大学出版社)

ORA-12514的故障是很多新手在连接Oracle数据库时经常遇到故障,它通常表示无法连接到数据库实例,这里姚远老师告诉大家如何排除这类故障。

症状

当尝试连接到Oracle数据库实例时,可能会收到ORA-12514错误消息。此错误通常会在Oracle客户端或应用程序中显示。
在这里插入图片描述
此外,还可能会在数据库服务器上的日志文件中看到类似于以下消息的记录:

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

产生原因

ORA-12514错误通常是由以下原因之一造成的:

  • 无效的服务名称:连接描述符中指定的服务名称不存在。例如,可能会发生拼写错误或者数据库实例名称更改而未及时更新连接描述符的情况。
oracle@Yao ~$ sqlplus sys/yaoyuan@localhost/orc1 as sysdba  SQL*Plus: Release 19.0.0.0.0 - Production on Wed Mar 1 16:00:59 2023 Version 19.3.0.0.0  Copyright (c) 1982, 2019, Oracle.  All rights reserved.  ERROR: ORA-12514: TNS:listener does not currently know of service requested in connect descriptor  
  • 监听程序未运行:如果Oracle数据库监听程序未运行,则无法连到数据库实例。此情况可能是由于监听程序未正确启动、网络连接故障或服务器故障等原因引起的。
oracle@yaoyuan ~$ sqlplus sys/yaoyuan@localhost/scott as sysdba  SQL*Plus: Release 19.0.0.0.0 - Production on Wed Mar 1 16:16:54 2023 Version 19.3.0.0.0  Copyright (c) 1982, 2019, Oracle.  All rights reserved.  ERROR: ORA-12541: TNS:no listener 

注意:这里的提示是“no listener”,和前面的“listener does not currently know of service requested in connect descriptor”不同。

解决办法

针对ORA-12514错误,可以采取以下措施来解决问题:

  • 检查连接描述符:确保连接描述符中指定的服务名称是正确的。如果服务名称发生变化,请更新连接描述符。例如下面两个连接,第一次失败,第二次成功,大家看看是什么问题呢?
oracle@Yao ~$ sqlplus sys/yaoyuan@localhost/orc1 as sysdba  SQL*Plus: Release 19.0.0.0.0 - Production on Wed Mar 1 16:29:24 2023 Version 19.3.0.0.0  Copyright (c) 1982, 2019, Oracle.  All rights reserved.  ERROR: ORA-12514: TNS:listener does not currently know of service requested in connect descriptor   Enter user-name: oracle@Yao ~$ sqlplus sys/yaoyuan@localhost/orcl as sysdba  SQL*Plus: Release 19.0.0.0.0 - Production on Wed Mar 1 16:29:40 2023 Version 19.3.0.0.0  Copyright (c) 1982, 2019, Oracle.  All rights reserved.   Connected to: Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production Version 19.3.0.0.0 

仔细看看就明白了,原来服务名是orcl被错误的写成了orc1。当然在生产环境,大部分时候服务名是在tnsnames.ora文件中配置的:

oracle@yaoyuan ~$ cat /u01/app/oracle/product/19.3.0/db_1/network/admin/tnsnames.ora ... ORCL =   (DESCRIPTION =     (ADDRESS_LIST =       (ADDRESS = (PROTOCOL = TCP)(HOST = oracleace)(PORT = 1521))     )     (CONNECT_DATA =       (SERVICE_NAME = orc1)     )   ) 

注意这里的SERVICE_NAME中有个不容易察觉的错误。
其它可能的问题和对应的解决方法包括:

  • 确认监听程序已运行:可以通过命令行或图形界面工具来检查监听程序是否正在运行。如果监听程序未运行,则需要启动它。
  • 检查网络连接:如果存在网络连接问题,则需要解决网络问题。例如,可以检查网络配置、防火墙设置等。
  • 检查数据库实例状态:如果数据库实例已停止或崩溃,则需要启动数据库实例。
    总之,ORA-12514错误通常表示无法连接到数据库实例。通过检查连接描述符、监听程序状态、网络连接和数据库实例状态等方面,可以找到并解决问题。

这篇文章解决了您不能连接Oracle数据库的问题吗?如果没有解决,您可以在下面留言描述您的问题,我会尽量抽时间给您解答,或者您可以加下方我的微信👇,拉您进入学习群提问。

相关内容

热门资讯

第三分钟关于!cloudpok... 第三分钟关于!cloudpoker怎么开挂(透视)真是有挂,专业教程(揭秘有挂)-哔哩哔哩1、实时c...
透视辅助!德州之星扫描器(透视... 透视辅助!德州之星扫描器(透视)原来是有挂,曝光教程(有挂苹果)-哔哩哔哩1、打开软件启动之后找到中...
透视挂!wepoker怎么设置... 透视挂!wepoker怎么设置房间,impoker辅助,演示教程(有挂辅助)-哔哩哔哩1、进入游戏-...
第九分钟科普!有没有人wepo... 第九分钟科普!有没有人wepoker(透视)总是存在有挂,曝光教程(有挂规律)-哔哩哔哩1、有没有人...
透视了解!wepoker开脚本... 透视了解!wepoker开脚本视频(透视)都是有挂,必赢教程(有挂技巧)-哔哩哔哩wepoker开脚...
透视挂透视!wpk真的有透视嘛... 透视挂透视!wpk真的有透视嘛,epoker透视,模板教程(真的有挂)-哔哩哔哩1)wpk真的有透视...
第3分钟必备!wepoker好... 第3分钟必备!wepoker好友局透视(透视)果然是有挂,专业教程(有挂头条)-哔哩哔哩1、全新机制...
透视代打!xpoker辅助器(... 您好,xpoker辅助器这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多...
透视教程!哈糖大菠萝有挂吗5个... 透视教程!哈糖大菠萝有挂吗5个常用方法,wepoker安装教程,步骤教程(有挂秘籍)-哔哩哔哩1、哈...
八分钟详细!wepoker免费... 八分钟详细!wepoker免费透视(透视)真是真的是有挂,必备教程(有挂细节)-哔哩哔哩wepoke...