Oracle连接找不到SID问题

错误描述

在这里插入图片描述

错误原因

  • 原因1:负载均衡时:
    由于oracle 是做的多节点,然后有一个公用的service_name,只有通过service_name去连接才能起到负载均衡的作用,而以cx_Oracle默认的连接串去连的话只能连接到实例名,而不能连接到service_name,所以oracle用service_name去匹配实例名,当然找不到。所以连接时必须指定连的是service_name而不是sid。

  • 原因2:你的user和name写反了,也就是你的用户名密码实例名输入不正确,若搞不清楚建议看下Navicat中oracle的连接信息。
    在这里插入图片描述

负载均衡时SID报错解决方案

修改SQLAlchemy连接字符串的连接方式

import cx_Oracle
from sqlalchemy import create_engine
ip = 'xx.xx.xx.xx'
port = 'xxxx'
uname = 'xxxxxx' # 用户名
pwd = 'xxxxxx' # 密码
tnsname = 'xxxxxx' # 实例名

try:
	#创建连接对象
	dsnStr = cx_Oracle.makedsn(ip, port, service_name=tnsname)
	connect_str = "oracle://%s:%s@%s" %(uname, pwd, dsnStr)
	engine = create_engine(connect_str, encoding=encoding)
	
	#cx_Oracle连接
	conn = cx_Oracle.connect(uname, pwd, dsn=dsnStr)
except:
	print('连接失败')

个人体会

  • 在公司测试环境下oracle数据库是实体的,单个的,独立的,不指定service_name也能正常连接。
  • 在客户生产环境下oracle是虚拟的,集群的,就一定要指定service_name才能连接。
  • 若程序找不到dll就报oracle的oracle.dll文件放到项目目录下。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值