tns的bug


修改了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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

inthirties

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值