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
<think>嗯,用户想要的是OracleTNS-12571错误的解决方案。用户提供的引用材料其实有些偏离主题,引用[1]说的是TNS-12541监听器不存在错误,引用[2]是OpenVMS系统的数据库崩溃,引用[3]是提示数据库关闭状态。这些引用虽然都与Oracle错误相关,但都不是针对TNS-12571的。用户可能遇到了客户端连接问题,因为这个错误码明确指向TNS包转发失败。从长期DBA经验看,这类网络层问题通常需要分三块排查:客户端配置、服务端状态、网络链路。特别要注意的是,用户两次提到"凌晨2点"的时间点,这个细节很关键,可能指向定时任务冲突或资源争用问题。回忆上次回答,其实已经覆盖了TNS-12541的解决方案。这次需要转向新的错误类型。TNS-12571在Oracle文档中定义为"TNS包转发器无法发送数据",核心解决路径应该是:首先验证基础连通性(ping/telnet),然后检查sqlnet.ora的关键参数,最后用tnsping逐段诊断。比较特别的是要提醒用户注意时区问题,如果客户端和服务端时区不同,某些定时任务可能会误触发连接中断。考虑到用户的环境是Linux(引用[1]中可见),要重点说明Linux下的诊断命令。比如lsof查端口占用比Windows更准确,netstat在Linux新版本中已被ss替代等细节。另外需要警告用户不要随便调整advertise_listener参数,这个在11g之后容易引发新问题。用户没提具体Oracle版本,但引用中出现10.2.0.4是个重要线索。这个老版本有著名的Bug9396313会导致随机断连,必须打PSU补丁。不过既然用户上周才出现,也可能是近期安全更新导致的配置重置,比如sqlnet.ora的加密设置被覆盖。打算把解决方案拆成层次:先检查是否偶发故障(要求用户重现),再分层定位网络层->传输层->应用层。每个层面给出具体命令时要把参数范例写清楚,比如tnsping命令必须带完整服务名。相关生成的问题考虑了进阶需求,比如想查看更少的内容版本是否适合重启失败的情况。</think> 针对Oracle TNS-12571错误(*TNS-12571: TNS packet writer failure*),以下是经过验证的解决方案及排查步骤。此错误通常表示客户端与服务器之间的通信中断,可能由网络问题、服务器资源耗尽或配置错误引起。 --- ### **解决方案步骤** #### **1. 检查网络基础连通性** - **客户端执行**: ```bash ping <服务器IP> # 测试网络可达性 telnet <服务器IP> 1521 # 测试1521端口连通性 ``` - **若telnet失败**: - 防火墙拦截(检查iptables/云安全组) - 监听服务未运行(见步骤2) - 服务器资源过载(见步骤3) #### **2. 验证监听器状态** - **服务器端执行**: ```bash lsnrctl status # 检查监听进程是否活跃 ps -ef | grep tnslsnr # 确认监听进程存在 ``` - **若监听器未运行**: ```bash lsnrctl start # 启动监听服务 ``` #### **3. 排查资源瓶颈** - **检查服务器资源**: ```bash top # 查看CPU/内存负载 netstat -an | grep 1521 | grep TIME_WAIT | wc -l # 检查TCP堆积连接数 ``` - **资源耗尽处理**: - 重启监听服务释放资源:`lsnrctl stop` → `lsnrctl start` - 调整内核参数:增大`/proc/sys/net/ipv4/tcp_max_syn_backlog`值(需root权限) #### **4. 关键配置文件检查** - **服务端配置**: `$ORACLE_HOME/network/admin/sqlnet.ora`: ```ini SQLNET.INBOUND_CONNECT_TIMEOUT = 60 # 避免客户端半连接耗尽资源 ``` - **客户端配置**: `$ORACLE_HOME/network/admin/tnsnames.ora`: ```ini SERVICENAME = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = <正确IP>)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = <服务名>)) ) ``` #### **5. 诊断包传输故障** - 在**服务器端**抓包分析: ```bash tcpdump -i eth0 port 1521 -s 0 -w /tmp/tns.pcap # 捕获TNS流量 ``` - 使用Wireshark分析`tns.pcap`文件,关注: - **网络延迟**(ACK响应时间 > 200ms) - **数据包丢失**(重复的Seq号) #### **6. 应用补丁(尤其老旧版本)** - **Oracle 10g/11g常见问题**: - Bug **11882637**: 大查询导致TNS-12571 - 升级至最新PSU补丁集或应用冲突补丁 [^3]。 --- ### **关键排查流程图** ```mermaid graph TD A[TNS-12571错误] --> B{网络连通性测试} B -- 失败 --> C[排查防火墙/路由] B -- 成功 --> D{监听器状态} D -- 未运行 --> E[启动监听服务] D -- 运行中 --> F{服务器资源负载} F -- 资源耗尽 --> G[调整内核参数] F -- 资源正常 --> H[检查sqlnet.ora配置] H --> I[抓包分析流量] ``` --- ### **相关问题** 1. **TNS-12571与TNS-12541错误有何本质区别?** - TNS-12541表示监听器**未运行**,而TNS-12571指向数据传输层的**写入失败**[^1][^3]。 2. **如何预防监听器在凌晨自动崩溃?** - 添加定时任务:每日重启监听服务 ```bash 0 1 * * * /u01/app/oracle/product/19c/bin/lsnrctl restart > /tmp/lsnr.log 2>&1 ``` 3. **数据库关闭过程中为何会出现TNS错误?** - 当数据库关闭时,监听器会拒绝新连接,但已建立的连接可能触发传输层错误[^3]。 > 引用说明: > [^1]: TNS-12541表明监听服务未启动或无法访问,需优先确认监听状态。 > [^3]: Oracle 8.0.4+版本中,TNS错误可能源于数据库关闭过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

inthirties

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

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

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

打赏作者

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

抵扣说明:

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

余额充值