现象:开发人员抱怨RAC数据库出现了时连得上时连不上的情况,用SQLPLUS一试,果然有这样的情况:
SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

ERROR:

ORA-12170: TNS: 连接超时

警告: 您不再连接到 ORACLE。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> select instance_name from sys.v_$instance;

INSTANCE_NAME

----------------

rac1

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

ERROR:

ORA-12170: TNS: 连接超时

警告: 您不再连接到 ORACLE。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL> conn system/*******@bjyd

已连接。

SQL>

检查两个节点主机和网络,均未开启防火墙:

[oracle@BJYD01 trace]$ su -

[root@BJYD01 ~]# service iptables status

Table: filter

Chain INPUT (policy ACCEPT)

num target prot opt source destination

Chain FORWARD (policy ACCEPT)

num target prot opt source destination

Chain OUTPUT (policy ACCEPT)

num target prot opt source destination

[root@BJYD02 ~]# service iptables status

Firewall is stopped.

[root@BJYD02 ~]#

sqlnet开启16级别的trace:

Fatal NI connect error 12170.

 VERSION INFORMATION:

 TNS for 32-bit Windows: Version 10.2.0.1.0 - Production

 Windows NT TCP/IP NT Protocol Adapter for 32-bit Windows: Version 10.2.0.1.0 - Production

 Time: 10-7?? -2013 09:03:38

 Tracing not turned on.

 Tns error struct:

 ns main err code: 12535

 TNS-12535: TNS: 2ù×÷3?ê±

ns secondary err code: 12560

 nt main err code: 505

 TNS-00505: 2ù×÷3?ê±

nt secondary err code: 60

 nt OS err code: 0

 Client address: <unknown>

[10-7?? -2013 09:13:58:741] ntt2err: entry

[10-7?? -2013 09:13:58:741] ntt2err: soc 284 error - operation=1, ntresnt[0]=505, ntresnt[1]=60, ntresnt[2]=0

[10-7?? -2013 09:13:58:741] ntt2err: exit

[10-7?? -2013 09:13:58:841] nttcni: exit

[10-7?? -2013 09:13:58:841] nttcon: exit

[10-7?? -2013 09:13:58:841] nserror: entry

[10-7?? -2013 09:13:58:841] nserror: nsres: id=0, op=65, ns=12535, ns2=12560; nt[0]=505, nt[1]=60, nt[2]=0; ora[0]=0, ora[1]=0, ora[2]=0

分析:

通常说来,ORA-12535/TNS-12535意味着在client和server之间的通讯时存在超时现象,有以下几种原因:

1.client和server之间设置了防火墙(包括OS层面的和网络层面的)

2.网速较慢导致出现超时

3.网卡故障

4.无法将主机名解释为IP地址也会导致超时

已经知道可能的原因了,那么可以通过排除法进行判断:

1,4经过检查可以排除,

2,3都存在可能。

首先我假定2--是网速较慢导致timeout,所以我在在sqlnet.ora中设置

SQLNET.INBOUND_CONNECT_TIMEOUT=180

(180秒我们认为是一个足够大的时间了,在慢速网络中基本可以排除超时的情况)

但设置了这个参数之后,问题依旧,再加之经过网络工程师的检查,没发现网络有异常的现象。

所以,我认为基本可以排除原因2。

那么进一步推测,是原因3导致的吗?

1)我发现了偶尔从节点1到节点2(Public IP)SSH不通的现象:

[oracle@BJYD01 ~]$

[oracle@BJYD01 ~]$ ssh BJYD02

ssh: connect to host BJYD02 port 22: Connection timed out

[oracle@BJYD01 ~]$

[oracle@BJYD01 ~]$ ssh BJYD02

Last login: Thu Jul 11 17:10:49 2013 from BJYD01

[oracle@BJYD02 ~]$

但SSH Private IP没这个问题。

从节点2到节点1SSH无论Public IP还是Private IP都没问题。

2)ifconfig查看,发现节点2的Public IP所在的eth0网卡有较严重的drop包现象(该处未截屏记录下来),

其它网卡以及节点1上的2个网卡均正常。

怀疑eth0网卡问题,尝试通过换掉eth0网卡解决问题。

解决方法:

最终将节点2的eth0网卡换掉之后,问题成功解决。

推断根本原因可能是:

1.节点2的eth0网卡老化导致故障;

2.节点2的eth0网口松动。

RAC ORA-12170 ora-12535/tns-12535的更多相关文章

  1. ORACLE RAC 下非缺省端口监听配置(listener.ora tnsnames.ora)

    不论是单实例还是RAC,对于非缺省端口下(1521)的监听器,pmon进程不会将service/instance注册到监听器,即不会实现动态注册.与单实例相同,RAC非缺省端口的监听器也是通过设置参数 ...

  2. Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)

    Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)的解决 [oracle@rac01 ~]$ sqlplus /nolog SQL*P ...

  3. Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)的解决

        Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)的解决 [oracle@rac01 ~]$ sqlplus /nolog S ...

  4. oracle的listener.ora sqlnet.ora tnsnames.ora三个文件的关联性

    学习:http://www.cnblogs.com/william-lee/archive/2010/10/20/1856261.html 之前因为安装的是windows server 2008 r2 ...

  5. listener.ora/sqlnet.ora/tnsnames.ora配置文件详解

    oracle网络配置 三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora ,都是放在$ORACLE_HOME/network/admin目录下. 英文说明: The ...

  6. Oracle RAC客户端tnsnames.ora相关配置及测试

    1.Oracle RAC服务端/etc/hosts部分内容如下 2.查看服务端的local_listener和remote_listener参数 3.客户端tnsnames.ora配置参考 3.1 1 ...

  7. ORACLE RAC 监听配置 (listener.ora tnsnames.ora)

    Oracle RAC 监听器的配置与单实例稍有不同,但原理和实现方法基本上是相同的.在Oracle中 tns进程用于为指定网络地址上的一个或多个Oracle 实例提供服务注册,并响应来自客户端对该服务 ...

  8. oracle的sqlnet.ora,tnsnames.ora,listener.ora三个配置文件

    总结: 1 .三个配置文件都是放在$ORACLE_HOME\network\admin目录下. 2 .sqlnet.ora确定解析方式 3 .listener.ora上设SID_NAME,通常用于JD ...

  9. oracle的sqlnet.ora , tnsnames.ora , Listener.ora 文件的作用(转)

    oracle网络配置三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora ,都是放在$ORACLE_HOME/network/admin目录下.1. sqlnet.o ...

  10. oracle错误(ORA:12154 ORA:01034 和 ORA:27101 ORA-18008 ORA-01081)

    按照正常操作流程,启动项目,发现项目报错,原因是连接不上oracle数据库, PLSQL连接时报错,错误码  ORA:12154 无法解析指定的连接标识符 第一次,遇到这个错误,在网上找了资料都是需要 ...

随机推荐

  1. javascript数组去重算法-----4

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. C++重载运算符的规则

    (1)C++不允许用户自己定义新的运算符,只能对已有的C++运算符进行重载. 例如,有人觉得BASIC中用“* *”作为幂运算符很方便,也想在C++中将“* *”定义为幂运算符,用“3* *5”表示3 ...

  3. PostMessage和SendMessage的区别

    1, PostMessage只把消息放入队列,不管其他程序是否处理都返回,然后继续执行,这是个异步消息投放函数.而SendMessage必须等待其他程序处理消息完了之后才返回,继续执行,这是个同步消息 ...

  4. SQL学习之HAVING过滤分组

    1.SQL除了能用Group By分组数据之外,SQL还允许过滤分组,规定包括那些分组,排除那些分组.例如,你可能想要列出至少有两个订单的所有顾客.为此,必须基于完整的分组而不是个别的行进行过滤. 基 ...

  5. Table显示边框

    style="border-bottom: 1px solid #CCCCCC;"

  6. 【ActionBar的使用】

    在AS工程中使用ActionBar 简单实用: 1.功能清单文件中指定主题标签属性Theme.Holo或其子类 <application android :theme="@androi ...

  7. Page.ClientScript.RegisterStartupScript 与 Page.ClientScript.RegisterClientScriptBlock 之间的区别

    Page.ClientScript.RegisterClientScriptBlock 在页面紧跟<form>之后,整个页面未完全加载完成. Page.ClientScript.Regis ...

  8. Oracle中的Truncate和Delete语句

    Oracle中的Truncate和Delete语句   首先讲一下,truncate命令:   语法:TRUNCATE  TABLE  table; 表格里的数据被清空,存储空间被释放. 运行后会自动 ...

  9. PL/SQL编程要点和注意点

    http://www.itpub.net/thread-1560427-3-1.html 1. 非关键字小写,关键字大写,用下划线分隔,用前缀区分变量与表列名.不强求变量初始值.2. 永远只捕获可预测 ...

  10. C# 微信公众平台开发(1)-- 服务器配置

    题记:最近公司需要开发微信服务号,由本人负责,以前虽然听过微信开发,但并没有认真的去了解,项目开发中,也边看文档边开发,记录自己的项目开发经验: 1.注册帐号--填写服务器配置 在https://mp ...