【Oracle报错】ORA-12514, TNS:listener does not currently know of service requested in conn
一、报错场景:
通过服务名去链接oracle客户端
二、解决思路:检查监听
-
是否加了白名单
-
加了白名单是否重启监听,重启才能生效
-
服务名和实例名检查下,是不是搞混了
三、具体方法
1、首先检查客户端的tnsnames.ora里面的host、port、service_name等是否正确
testOracle =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 1.1.1.1)(PORT = 1521))
)
(CONNECT_DATA =
(SERVER = test)
(SERVICE_NAME = thesis)
)
)
2、检查监听状态
lsnrctl status
四、其他方法
1、启动监听 lsnrctl start
2、通过sqlplus / as sysdba ,执行startup来启动数据库,发现报错,initORCL.ora不存在。
3、进入对应目录,打开spfileorcl.ora,发现db_name=orcl
4、查看环境变量 cat ~/.bash_profile,发现ORACLE_SID=ORCL
5、conn / as sysdba,然后startup nomount
startup nomount选项启动实例,但不安装数据库。当数据库以这个模式启动时,参数文件被读取;后台进程和内存结构被启动;但它们不被附加或与数据库的磁盘结构进行通信。当实例处于这个状态时,数据库是不可使用的。
通常启动到这里可以做create database ,create or recreate control file 或者是mount standby database等动作,修改parameter也是可以的。
6、alter database mount; alter database open;
oracle数据库启动分三个步骤:nomount,mount,open; 而startup是数据库从开始阶段的启动,需要经过上述三个步骤。alter database open是数据库处于mount状态,从mount状态打开数据库的命令。因此,执行startup nomount,alter database mount; alter database open;正是依次执行启动数据库
7、show parameter name;
通过该命令可以查看数据库一些参数,从而判断是否是因为参数配置问题导致。
8、发现oracleName等参数为orcl
9、vi ~/.bash_profile
将ORACLE_SID的值改为小写,即orcl,并执行source ~/.bash_profile来使得配置生效。
10、修改ORACLE_HOME下network/admin下的listener.ora与客户端对应的tnsnames.ora
11、重启监听 lsnrctl restart
12、登录数据库:sqlplus system/oracle@//localhost:1521/orcl;
AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。
更多推荐


所有评论(0)