使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
来源:互联网 发布:友价房产源码 编辑:程序博客网 时间:2024/06/03 02:47
很多时候为了优化我们的启动项把oracle的服务禁止了,可是重启启动之后使用PLSQL登陆oracle时会出现无监听程序,这说明我们有一些服务没有启动。我们先查看一下oracle的服务是否启动,查看方法是计算机-->>管理-->>服务和应用程序-->>服务,进行查找oracle的启动服务,
进入之后具体情况如下图:
在这里可以看到oracle的启动服务OracleServiceORCL和OracleOraDb11g_home1TNSLister,OracleDBCConsoleorcl等启动项都是没有启动,在这里把我上图中红色矩形框内的服务启动就可以了。
在oracle11安装成功之后,用PLSQL 登陆的时候提示ORA-12541: TNS:无监听程序,无法进行登陆。在这里总结了一下解决此类的办法,希望可以帮到大家。
第一种方法:由于地址分配不对,我们这里需要重新配置一下本机的环境。
从oracle的安装环境中找到network,如图:
我的oracle安装到了D盘,所以你根据自己安装路径进行寻找,例如:D:\app\Administrator\product\11.2.0\dbhome_2\NETWORK
LISTENER_ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORCL)
)
)
ORACLR_CONNECTION_DATA=
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY =EXTPROC1521))
)
(CONNECT_DATA =
(SID = CLRExtProc)
(PRESENTATION = RO)
)
)
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST =localhost)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORCL)
)
)
修改后的代码{
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORCL)
)
)
把里面的localhost修改成电脑随机生成的IP。
机名输入localhost或127.0.0.1都会提示无监听程序。由于自动分配的IP地址会有变动,所以将oracle值中的host改成本机的计算机名,保存修改后的tnsnames.ora。再次连接(10.1.10.183/orcl)数据库,出错问题解决。
第二种方法是具体查看oracle的系统。
具体流程如下:
第一步:查看oracle的log日志。
发现下面错误:
TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Production on 20-9月 -2008 10:25:26
Copyright (c) 1991,2005, Oracle. All rights reserved.
系统参数文件为D:\oracle\product\10.2.0\db_1\network\admin\listener.ora
写入D:\oracle\product\10.2.0\db_1\network\log\listener.log的日志信息
写入D:\oracle\product\10.2.0\db_1\network\trace\listener.trc的跟踪信息
跟踪级别当前为0
监听:
(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1ipc)))
监听该对象时出错:(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=0.5.0.5)(PORT=1521)))
TNS-12545: 因目标主机或对象不存在,连接失败
TNS-12560: TNS: 协议适配器错误
TNS-00515: 因目标主机或对象不存在,连接失败
32-bit Windows Error: 49: Unknown error
不再监听:(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1ipc)))
第二步:查看oracle的监听程序是否启动
进入dos窗口,快捷键是 菜单键+R,输入cmd,在dos窗口中输入lsnrctlstatus 查看你的运行状态,如果结果如下:
LSNRCTL for 32-bitWindows: Version 10.2.0.1.0 - Production on 20-9月 -2008 10:5
0:44
Copyright (c) 1991,2005, Oracle. All rights reserved.
正在连接到(DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1)))
TNS-12541: TNS: 无监听程序
TNS-12560: TNS: 协议适配器错误
TNS-00511: 无监听程序
32-bit Windows Error: 2: No such file or directory
正在连接到(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=0.5.0.5)(PORT=1521)))
TNS-12535: TNS: 操作超时
TNS-12560: TNS: 协议适配器错误
TNS-00505: 操作超时
32-bit Windows Error: 60: Unknown error
第三种:重置监听程序,以及配置本地网络名称
我的电脑是window 7,所以从开始菜单中找到oracle的安装目录,找到Net Configuration Assistant打开之后,进行配置。主要配置是都过oracle自带的管理工具实现的,具体如下图:
这里的图片用的是网上搜寻的,不过方法我都使用了,因为那时候问题真的很多,换了好几种方法。更多的知识朋友们可以搜寻一下我的公众平台:牧笛助手,账号:MuDi_Assistant,最近刚开始筹建,打算分享学习中的案例已经各种问题bug的解决方法。扫一扫二维码:
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- 连接Oracle时报错ORA-12541: TNS: 无监听程序
- 连接Oracle时报错ORA-12541: TNS: 无监听程序
- 连接Oracle时报错ORA-12541: TNS: 无监听程序
- 连接Oracle时报错ORA-12541: TNS: 无监听程序
- 使用PL/SQL连接Oracle时报错ORA-12541: TNS: 无监听程序
- 连接Oracle11g时报错ORA-12541: TNS: 无监听程序
- PLSQL连接Oracle报错ORA-12541:TNS:无监听程序
- PLSQL连接提示ORA-12541 TNS 无监听程序
- plsql无法连接linux下的oracle服务器,提示:ora-12541:TNS 无监听程序
- plsql无法连接linux下的oracle服务器,提示:ora-12541:TNS 无监听程序
- 2 plsql连接oracle问题:ora-12541:TNS:无监听程序解决办法及思路
- plsql ORA-12541:TNS:无监听程序
- 用PL/SQL Developer(远程)连接Oracle 11g时报错“ORA-12541: TNS: 无监听程序”,解决办法
- ORA-12541:TNS:无监听程序 远程连接oracle失败
- nginx 反向代理和负载均衡
- DetachedCriteria多条件查询or,disjunction
- 相对布局
- 在mac OS上通过终端命令显示文件夹路径
- [C++设计模式] strategy 策略模式
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- Unity3D项目程序加密2——对dll进行混淆
- android textview 实现跑马灯效果
- 1005. Spell It Right (20)
- HDU 5282 Senior's String (两次dp LCS预处理)
- Android Studio SDK 更新方法
- 逻辑回归分类器(Logistic Regression Classifier)
- GRE写作必备句型
- Linux中link,unlink,close,fclose详解