修改了listener的端口,没有使用默认的端口1521
带来的几个错误,
1. lsnrctl status出错
[oracle@solaris ~]lsnrctl status
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:42:47
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
TNS-12541: TNS:no listener
TNS-12560: TNS:protocol adapter error
TNS-00511: No listener
Solaris Error: 146: Connection refused
2. lsnrctl stop出错
[oracle@solaris ~]lsnrctl stop
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:57:17
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
TNS-12541: TNS:no listener
TNS-12560: TNS:protocol adapter error
TNS-00511: No listener
Solaris Error: 146: Connection refused
3. tnsping tnsname是OK的,但是tnsping id/hostname出错
[oracle@solaris ~]tnsping localhost
TNS Ping Utility for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:58:11
Copyright (c) 1997, 2005, Oracle. All rights reserved.
Used parameter files:
Used HOSTNAME adapter to resolve the alias
Attempting to contact (DESCRIPTION=(CONNECT_DATA=(SERVICE_NAME=localhost.))(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521)))
TNS-12541: TNS:no listener
根据出错的信息,可以马上看到这里的端口都是1521,所以可以马上断定是和修改默认监听端口有关。
修改了默认的监听端口,这些命令立马失去了作用,
解决的方法,加入默认的一个监听配置,默认的监听配置和上面的端口一致,或者是在以上的监听里加上默认的1521端口的绑定。
先看方法一
默认的监听名字为listener,当你的lsnrctl没有指定具体的监听名字时,oracle会在你的listener.ora里找寻 LISTENER=的配置,如果灭有找到的话,oracle会用默认的端口,主机名来启动listener。
所以上面的解决方法,在listener.ora里加上
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 31521))
)
)
即可解决问题了,估计oracled的实现中根据默认的监听找到相应的端口号,然后去进行相应的操作了。
方法二
就是直接在监听里加上1521的绑定端口
这是我启动的监听,名字为solaris,如果不想添加默认的监听的话,可以修改这个监听,加上默认1521的监听
LISTENER_SOLARIS =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 31521)(IP = FIRST))
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.216)(PORT = 31521)(IP = FIRS
T))
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 1521))
)
)
不过以上两种方法能够解决的是lsnrctl出现的问题,tnsping localhost,这个问题还是不能解决,毕竟tnsname是和listener.ora分割开的,。使用tnsping并不会用到 listener.ora的配置,估计tnsping ip/hostname是直接使用了1521进行了尝试,除非你指定了tnsname,应该tnsname里指定了ip外,还指定了port。
这里算不算上是tns和监听的bug了。不过这个已经俨然不重要了,毕竟已经有多个方法对待他。
最后不使用上面的方法,你也可以避开这个问题。
就是lsnrctl带上你的监听名,这样他就知道查看哪个监听了。和启动一样的方式。
[oracle@solaris ~]lsnrctl status listener_solaris
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 22:26:27
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sol-vip1)(PORT=31521)(IP=FIRST)))
STATUS of the LISTENER
[oracle@solaris ~]lsnrctl stop listener_solaris
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 22:27:47
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sol-vip1)(PORT=31521)(IP=FIRST)))
The command completed successfully
带来的几个错误,
1. lsnrctl status出错
[oracle@solaris ~]lsnrctl status
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:42:47
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
TNS-12541: TNS:no listener
TNS-12560: TNS:protocol adapter error
TNS-00511: No listener
Solaris Error: 146: Connection refused
2. lsnrctl stop出错
[oracle@solaris ~]lsnrctl stop
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:57:17
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
TNS-12541: TNS:no listener
TNS-12560: TNS:protocol adapter error
TNS-00511: No listener
Solaris Error: 146: Connection refused
3. tnsping tnsname是OK的,但是tnsping id/hostname出错
[oracle@solaris ~]tnsping localhost
TNS Ping Utility for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 21:58:11
Copyright (c) 1997, 2005, Oracle. All rights reserved.
Used parameter files:
Used HOSTNAME adapter to resolve the alias
Attempting to contact (DESCRIPTION=(CONNECT_DATA=(SERVICE_NAME=localhost.))(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521)))
TNS-12541: TNS:no listener
根据出错的信息,可以马上看到这里的端口都是1521,所以可以马上断定是和修改默认监听端口有关。
修改了默认的监听端口,这些命令立马失去了作用,
解决的方法,加入默认的一个监听配置,默认的监听配置和上面的端口一致,或者是在以上的监听里加上默认的1521端口的绑定。
先看方法一
默认的监听名字为listener,当你的lsnrctl没有指定具体的监听名字时,oracle会在你的listener.ora里找寻 LISTENER=的配置,如果灭有找到的话,oracle会用默认的端口,主机名来启动listener。
所以上面的解决方法,在listener.ora里加上
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 31521))
)
)
即可解决问题了,估计oracled的实现中根据默认的监听找到相应的端口号,然后去进行相应的操作了。
方法二
就是直接在监听里加上1521的绑定端口
这是我启动的监听,名字为solaris,如果不想添加默认的监听的话,可以修改这个监听,加上默认1521的监听
LISTENER_SOLARIS =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 31521)(IP = FIRST))
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.216)(PORT = 31521)(IP = FIRS
T))
(ADDRESS = (PROTOCOL = TCP)(HOST = sol-vip1)(PORT = 1521))
)
)
不过以上两种方法能够解决的是lsnrctl出现的问题,tnsping localhost,这个问题还是不能解决,毕竟tnsname是和listener.ora分割开的,。使用tnsping并不会用到 listener.ora的配置,估计tnsping ip/hostname是直接使用了1521进行了尝试,除非你指定了tnsname,应该tnsname里指定了ip外,还指定了port。
这里算不算上是tns和监听的bug了。不过这个已经俨然不重要了,毕竟已经有多个方法对待他。
最后不使用上面的方法,你也可以避开这个问题。
就是lsnrctl带上你的监听名,这样他就知道查看哪个监听了。和启动一样的方式。
[oracle@solaris ~]lsnrctl status listener_solaris
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 22:26:27
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sol-vip1)(PORT=31521)(IP=FIRST)))
STATUS of the LISTENER
[oracle@solaris ~]lsnrctl stop listener_solaris
LSNRCTL for Solaris: Version 10.2.0.1.0 - Production on 04-APR-2010 22:27:47
Copyright (c) 1991, 2005, Oracle. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sol-vip1)(PORT=31521)(IP=FIRST)))
The command completed successfully
- 提供Oracle管理/故障处理/优化/安装/RAC/备份恢复技术服务,提供专业的Oracle培训和咨询服务。
- 邮件: inthirties@gmail.com
- MSN: inthirties@hotmail.com
- QQ: inthirties@qq.com
- 电话: 13828706466
- 技术博客 http://blog.csdn.net/inthirties
- 个人站点 http://blog.inthirties.com