tomcat启动程序时,无法连接数据库(报错未知的SID) ,plsql可正常登录

tomcat启动报错无法连接数据库,记录下解决方案。

转自:https://blog.csdn.net/zust6314/article/details/25567543

参考:https://blog.csdn.net/king_818/article/details/53034374

-----------------------------------------------------------------------------------------------------------------------------------

程序启动报错:ORA-12505;PL/SQL却可以登录
一、异常{

ORA-12505, TNS:listener does not currently know of SID given in connect descriptor
The Connection descriptor used by the client was:
10.190.121.95:1521:sxzhdb

}

二、查询{

ORA-12505:TNS: 监听程序当前无法识别连接描述符中所给出的 SID

---

SID:是一个数据库的唯一标识符!是建立一个数据库时系统自动赋予的一个初始ID,SID主要用于在一些DBA操作以及与操作系统交互,从操作系统的角度访问实例名,必须通过ORACLE_SID,且它在注册表中也是存在的.

---

ORACLE_SID就是Oracle System Identifier.在Oracle系统中,ORACLE_SID以环境变量的形式出现,当Oracle实例启动时,操作系统上fork的进程必须通过这个SID将实例与其他实例区分开来,这就是SID的作用。

}

三、修改{

将原来的:jdbc:oracle:thin:@10.190.121.95:1521:sxzhdb

改为:jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.190.121.95)(PORT=1521))(LOAD_BALANCE=yes))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=sxzhdb)))

后,程序连接数据库OK。

------

最后将:url简化为:jdbc:oracle:thin:@(description=(address=(protocol=tcp)(port=1521)(host=10.190.121.95))(connect_data=(service_name=sxzhdb)))

----

其中address的三个属性protocol,port,host顺序可以变化,大小写均可以。

结构为:

description

address

protocol

host

port

connect_data

service_name

}

转载于:https://www.cnblogs.com/xxww/p/9523479.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
问题描述意味着在连接Linux系统上的Oracle数据库出现了监听程序无法识别的错误。解决此问题需要以下步骤: 1. 首先,确保Oracle数据库监听程序正在运行。使用以下命令检查监听程序的状态: ``` lsnrctl status ``` 如果监听程序没有运行,请启动它: ``` lsnrctl start ``` 2. 如果监听程序正在运行但无法识别,请检查监听程序的配置文件,通常是 `listener.ora`。此文件通常位于 `$ORACLE_HOME/network/admin/` 目录中。确保配置文件中指定了正确的服务名称和端口号。 3. 在配置文件中,查看是否存在与数据库实例相对应的服务。每个数据库实例都应该在配置文件中定义一个服务。如果没有,请添加一个服务项,例如: ``` SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = ORCL) (ORACLE_HOME = /u01/oracle/product/12.2.0/dbhome_1) (SID_NAME = ORCL) ) ) ``` 4. 确保在客户端连接Oracle数据库使用了正确的主机名、端口号和服务名称。检查连接字符串是否与监听程序配置文件中的定义匹配。 5. 如果以上步骤都无效,请尝试重新启动整个Oracle实例。首先关闭数据库: ``` sqlplus / as sysdba shutdown immediate; exit ``` 然后重新启动实例: ``` sqlplus / as sysdba startup; exit ``` 如果问题仍然存在,请检查操作系统的防火墙设置,确保端口号被允许通过。另外,还可以检查Linux系统日志文件以获取更详细的错误信息,并查阅Oracle文档或寻求Oracle技术支持的帮助来解决此问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值