十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
两个节点host,ipvip ,scan的信息 #eth0-Public IP 162.12.0.1 cqltjcpt1 162.12.0.3 cqltjcpt2 #eth2 PRIVATE IP 192.12.0.1 cqltjcpt1-prvi 192.12.0.3 cqltjcpt2-prvi #VIP 162.12.0.5 cqltjcpt1-vip 162.12.0.7 cqltjcpt2-vip #SCAN 162.12.0.9 cqltjcptscan 11G rac中,监听文件默认配置在grid用户下 [root@cqltjcpt2 ~]# su - grid [grid@cqltjcpt2 ~]$ cd $ORACLE_HOME [grid@cqltjcpt2 grid]$ cd network/admin/ [grid@cqltjcpt2 admin]$ ll -rw-r--r-- 1 grid oinstall 189 Jan 7 21:21 endpoints_listener.ora -rw-r--r-- 1 grid oinstall 350 Jan 7 21:21 listener.ora drwxr-xr-x 2 grid oinstall 4096 Jan 7 21:04 samples -rw-r--r-- 1 grid oinstall 205 May 11 2011 shrept.lst -rw-r--r-- 1 grid oinstall 227 Jan 7 21:21 sqlnet.ora Oracle 11.2版本后,有一个新的监听文件endpoints_listener.ora被引进,里面的内容是节点的IP和VIP信息 Endpoints_listener.ora 文件的作用是向后兼容11.2版本以前的数据库,DBCA建库时,需要通过获取endpoints的位置信息来配置数据库参数和tnsnames [grid@cqltjcpt2 admin]$ more endpoints_listener.ora LISTENER_CQLTJCPT2=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP) (HOST=cqltjcpt2-vip)(PORT=1521))(ADDRESS=(PROTOCOL=TCP)(HOST=162.12.0.3)(PORT=1521)(IP=FIRST)))) 由于用hosts解析配置本例中没有配置DNS,只有一个scan listener 此时scan监听只运行在Node1上 [grid@cqltjcpt2 admin]$ ps -ef | grep tnslsnr grid 9840 1 0 Jan07 ? 00:00:22 /u01/oracle/grid/bin/tnslsnr LISTENER -inherit grid 22674 21922 0 11:08 pts/1 00:00:00 grep tnslsnr [grid@cqltjcpt2 ~]$ ssh cqltjcpt1 [grid@cqltjcpt1 ~]$ ps -ef | grep tnslsnr grid 8211 1 0 Jan07 ? 00:00:44 /u01/oracle/grid/bin/tnslsnr LISTENER -inherit grid 8380 1 0 Jan07 ? 00:00:02 /u01/oracle/grid/bin/tnslsnr LISTENER_SCAN1 -inherit grid 22060 22021 0 11:08 pts/1 00:00:00 grep tnslsnr 从ps -ef输出可以看到,无论是scan监听,还是本地监听都是运行在grid用户的oracle_home下 NODE2本地监听指向的是vip地址162.12.0.7 ,因为rac是通过vip对外提供服务 [oracle@cqltjcpt2 ~]$ sqlplus / as sysdba SQL> show parameter local_listener NAME TYPE VALUE --------------- ---------- -------------------------------------------------------------------------------- local_listener string (DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=162.12.0.7)(PORT=1521)))) remote_listener指向的是scan监听名 SQL> show parameter remote_listener NAME TYPE VALUE ----------------- ----------- ------------------------------ remote_listener string cqltjcptscan:1521 切换至grid用户 [root@cqltjcpt2 ~]# su - grid [grid@cqltjcpt2 ~]$ cd $ORACLE_HOME/network/admin [grid@cqltjcpt2 admin]$ ls endpoints_listener.ora listener.ora samples shrept.lst sqlnet.ora 查看监听文件内容 [grid@cqltjcpt2 admin]$ more listener.ora LISTENER_SCAN1=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER_SCAN1)))) LISTENER=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER)))) ENABLE_GLOBAL_DYNAMIC_ENDPOINT_LISTENER=ON ENABLE_GLOBAL_DYNAMIC_ENDPOINT_LISTENER_SCAN1=ON 最下面两行参数涉及ENABLE_GLOBAL_DYNAMIC_ENDPOINT参数,ENABLE_GLOBAL_DYNAMIC_ENDPOINT参数的作用是允许监听程序接受针对oracle 11.2版本之前未进行动态注册的连接 查看监听状态,可以看到cqltgsqz2实例已经运行 [grid@cqltjcpt2 ~]$ srvctl status listener Listener LISTENER is enabled Listener LISTENER is running on node(s): cqltjcpt1,cqltjcpt2 [grid@cqltjcpt2 ~]$ lsnrctl status listener LSNRCTL for Linux: Version 11.2.0.3.0 - Production on 08-JAN-2013 10:58:30 Copyright (c) 1991, 2011, Oracle. All rights reserved. Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER))) STATUS of the LISTENER ------------------------ Alias LISTENER Version TNSLSNR for Linux: Version 11.2.0.3.0 - Production Start Date 07-JAN-2013 22:44:03 Uptime 0 days 12 hr. 14 min. 26 sec Trace Level off Security ON: Local OS Authentication SNMP OFF Listener Parameter File /u01/oracle/grid/network/admin/listener.ora Listener Log File /u01/oracle/app/oracle/diag/tnslsnr/cqltjcpt2/listener/alert/log.xml Listening Endpoints Summary... (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER))) (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=162.12.0.3)(PORT=1521))) (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=162.12.0.7)(PORT=1521))) Services Summary... Service "+ASM" has 1 instance(s). Instance "+ASM2", status READY, has 1 handler(s) for this service... Service "cqlthxqf" has 1 instance(s). Instance "cqlthxqf2", status READY, has 1 handler(s) for this service... Service "cqlthxqfXDB" has 1 instance(s). Instance "cqlthxqf2", status READY, has 1 handler(s) for this service... Service "cqlthxqz" has 1 instance(s). Instance "cqlthxqz2", status READY, has 1 handler(s) for this service... Service "cqlthxqzXDB" has 1 instance(s). Instance "cqlthxqz2", status READY, has 1 handler(s) for this service... Service "cqltjcpt" has 1 instance(s). Instance "cqltjcpt2", status READY, has 1 handler(s) for this service... Service "cqltjcptXDB" has 1 instance(s). Instance "cqltjcpt2", status READY, has 1 handler(s) for this service... The command completed successfully