Oracle 11g RAC 监听器使用中出现no services以及no li(2)

                                                DRESS=(PROTOCOL=TCP)(HOST=RACS

                                                 CAN.localdomain.)(PORT=1521)))

                                                )

SQL> select instance_name,status from v$instance;

INSTANCE_N STATUS

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

RACDB2    OPEN

我们观察到数据库实例使用的是scan-ip

那是不是就是应为使用的ip情况的不同,listener监听器中的监听服务不同呢?

我们来测试一把:

此处我们只测试asm实例的参数local_listener即可,其他服务的雷同。

SQL> alter system set local_listener='(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=RACSCAN.localdomain.)(PORT=1521))))';

System altered.

SQL> host lsnrctl status

Listener Parameter File  /u/app/11.2.0/grid/network/admin/listener.ora

Listener Log File        /u/app/grid/diag/tnslsnr/RAC01/listener/alert/log.xml

Listening Endpoints Summary...

  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER)))

  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=10.134.30.27)(PORT=1521)))

  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=10.134.30.47)(PORT=1521)))

The listener supports no services

The command completed successfully

我们观察到监听还是那个监听,但是服务却不是那个服务了,此时no services了。

此时我们在透过tnsnames.ora文件的配置从客户端登陆数据库时就会出现如下错误:

ORA-12520: TNS:listener could not find available handler for requested type of

server

Enter user-name:

无论是vip还是透过scan-ip都是不行的。从此处我们可以得出结论:ASM实例的监听地址必须是VIP而不能是scan-ip。否侧会出现上述报错。

ASM实例的监听器修改回来。

alter system set local_listener='(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=RAC01-vip)(PORT=1521))))';

那么数据库实例应该使用那个类型的ip呢,是scan-ip还是vip呢,其实这两个ip都行,就看你怎么用了。如果local_listener参数配置为指向vip,此时客户端只能透过vip访问数据库,如果local_listener参数配置为scan-ip此时客户端必须透过scan-ip访问,否则登陆同样报错如下:

ORA-12520: TNS:listener could not find available handler for requested type of

server

Enter user-name:

总结:

    oracle11g RAC环境中,监听器是由grid账号来维护的,此外ASM实例使用的一定是vip,数据库实例vipscan-ip均可使用。如果数据库参数local_listener配置了vip,此时客户端只能透过vip访问数据库,如果数据库参数local_listener参数设置为scan-ip此时客户端只能透过scan-ip访问数据库。建议使用scan-ip,这样数据库在增删节点的时候就不会影响到客户端的使用,客户端也无需也节点的变化而修改配置。Oracle官方建议在使用scan-ip时最少配置3scan-ip。这样透过冗余可防止某个scan-ip不可用导致客户端无法访问数据库。

以上测试仅为个人测试分析,若有不对请各位及时指出,鄙人自当万分感谢。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/1e42c53e677660e6e40c43769fed297a.html