和这个人有相反的问题。 TNSPING OK 但 sqlplus 给出 ORA-12154?
我正在尝试在 VMWare Workstation 中的 VM 上安装 Oracle。我尝试在以下位置安装 Oracle 11g 和 12c:
- 视窗服务器 2008 R2
- 视窗服务器 2012 R2
- Windows Server 2016 Tech Preview 3(出于绝望)
在每种情况下,我都会收到“未满足最低要求”的对话框。当我检查 AppData 中的安装日志时,我得到了这个。
检查是否可以确定 localhost 的 IP 地址...严重:CVU 不支持目标环境
我尝试将我的虚拟机设置为使用 NAT 以及使用桥接连接。根据此线程,可以忽略“CVU 错误”。https://community.oracle.com/thread/2478769
Oracle 每次都安装成功,它会自动在我的 tnsnames.ora 文件中插入一个条目。我可以sys
通过执行以用户身份连接sys@TNS_ENTRY as sysdba
但是第二次我尝试使用 EZCONNECT 语法,它不起作用。例如:
>sqlplus /nolog
>connect sys@localhost:1521/service
然后我得到一个 ORA-12504: TNS:Listener is not given the SERVICE_NAME in CONNECT_DATA。这很奇怪,因为我什至没有尝试使用 tnsnames.ora 文件中的条目进行连接。我尝试在 Net Manager 的 sqlnet.ora 配置管理器中提升 EZCONNECT。
我已验证 Oracle 安装程序确实将侦听器放在我的名为“LISTENER”的机器上
我有另一台在裸机上运行 Windows Server 2012 R2 的服务器。我交叉检查了所有 tns、侦听器和 sqlnet 配置,它们都相同(由 11g 安装程序创建的默认配置)
我知道 VMWare 在他们的虚拟机上支持 Oracle 数据库。我试图坚持这里列出的这些最佳实践。http://www.vmware.com/files/pdf/partners/oracle/Oracle_Databases_on_VMware_-_Best_Practices_Guide.pdf
我检查lsnrctl
以确保它正确加载配置。当我重新启动侦听器时,我在那里看到了我的端点
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=mymachinename)(PORT=1521)))
防火墙已关闭。
这是 tnsping 的结果:
C:\Users\Administrator>tnsping 本地主机
适用于 64 位 Windows 的 TNS Ping 实用程序:版本 11.2.0.1.0 - 2015 年 9 月 17 日 11:36:02 生产
版权所有 (c) 1997、2010,甲骨文。版权所有。
使用的参数文件:C:\app\Administrator\product\11.2.0\dbhome_1\network\admin\sqlnet.ora
使用 EZCONNECT 适配器解析别名 Attempting to contact (DESCRIPTION=(CONNECT_DATA=(SERVICE_NAME=))(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))) OK (0 ms)
^ 看起来与我的 2012 R2 裸机服务器的 tnsping 完全相同,它上面有 11g 可以工作。
我在这里错过了一些非常简单的东西吗?我对此束手无策。