Oracle数据库数据恢复、性能优化

找回密码
注册
搜索
热搜: 活动 交友 discuz
发新帖

8

积分

1

好友

20

主题
1#
发表于 2013-1-29 17:36:23 | 查看: 3973| 回复: 2
本帖最后由 bj-jn 于 2013-1-30 10:55 编辑

环境描述:版本/10.2.0.4.0  客户端IP:10.3.29.10  rac的vip:10.1.91.12/22
节点1:(racdb1)
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
local_listener                       string      (ADDRESS=(PROTOCOL=TCP)(HOST=10.1.91.12)(PORT=1521))
remote_listener                      string    LISTENERS_RACDB

节点2:(racdb2)
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
local_listener                       string      (ADDRESS=(PROTOCOL=TCP)(HOST=10.1.91.22)(PORT=1521))
remote_listener                      string   LISTENERS_RACDB

LISTENERS_RACDB =
  (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.91.12)(PORT = 1521))
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.91.22)(PORT = 1521))
  )

测试步骤:
1.配置客户端的tnsnames.ora
racdb_taf =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.91.12)(PORT = 1521))
    (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.91.22)(PORT = 1521))
    (LOAD_BALANCE = yes)
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = racdb)
        (FAILOVER_MODE =
        (TYPE = session)
        (METHOD = basic)
       (RETRIES = 180)
       (DELAY = 1)
      )
    )
  )

2.使用racdb_ctf连接串连接rac实例
SQL>select inst_id,sid from gv$session where sid=userenv('sid');
   INST_ID        SID
-----------   ---------
         1           126

3.登陆rac节点1,讲server process给kill掉
SQL> select spid from v$process a,v$session b
  2  where a.addr=b.paddr and sid=126;

SPID
------------
7772

SQL> host kill -9 7772

4.返回客户端的sqlplus中执行如下sql这时被hang住
SQL>  select instance_name from v$instance
  /


5.通过监控2个节点上的监听日志发现客户端正不断的尝试连接两个节点
29-JAN-2013 17:09:05 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=racdb)(FAILOVER_MODE=(TYPE=session)(METHOD=basic)(RETRIES=180)(DELAY=1))(CID=(PROGRAM=E:\oracle\product\10.2.0\db_1\bin\sqlplus.exe)(HOST=LENOVO-BC500838)(USER=Administrator))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.3.29.10)(PORT=1128)) * establish * racdb * 0
29-JAN-2013 17:09:06 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=racdb)(FAILOVER_MODE=(TYPE=session)(METHOD=basic)(RETRIES=180)(DELAY=1))(CID=(PROGRAM=E:\oracle\product\10.2.0\db_1\bin\sqlplus.exe)(HOST=LENOVO-BC500838)(USER=Administrator))(INSTANCE_NAME=racdb1)) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.3.29.10)(PORT=1131)) * establish * racdb * 0
29-JAN-2013 17:09:07 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=racdb)(FAILOVER_MODE=(TYPE=session)(METHOD=basic)(RETRIES=180)(DELAY=1))(CID=(PROGRAM=E:\oracle\product\10.2.0\db_1\bin\sqlplus.exe)(HOST=LENOVO-BC500838)(USER=Administrator))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.3.29.10)(PORT=1132)) * establis

结论:经过观察发现此现象是由于tnsnames.ora中(RETRIES=180)(DELAY=1)这两个参数导致客户端不断的去连接节点1 or节点2,将这两个参数去掉之后解决。
疑问:随后我将客户端中tnsnames.ora的rac节点ip换到另外一套rac环境,sql hang住现象消失,为什么在两套rac环境中这两个参数表现的结果却完全不一样了,求解释!
我的理解是retries应该是重新连接失败后的次数上限,既然连接再次建立成功为什么还要一直不断的发起新的retry 连接?
2#
发表于 2013-1-30 12:57:45
1. 你用的是什么用户user去测试TAF?
2. 你的客户端版本是多少?

回复 只看该作者 道具 举报

3#
发表于 2013-1-30 13:46:35
刘大,我用的是自己建立的普通测试用户tl,sqlplus版本是10.2.0.4.0

回复 只看该作者 道具 举报

您需要登录后才可以回帖 登录 | 注册

QQ|手机版|Archiver|Oracle数据库数据恢复、性能优化

GMT+8, 2024-11-16 06:54 , Processed in 0.045008 second(s), 20 queries .

Powered by Discuz! X2.5

© 2001-2012 Comsenz Inc.

回顶部
TEL/電話+86 13764045638
Email service@parnassusdata.com
QQ 47079569