您的位置:首页 > 数据库 > Oracle

Oracle RAC CRS-0184 --Cannot communicate with the CRS daemon

2016-03-02 19:10 465 查看
Oracle 11gR2 下RAC 安装后,启动CRS. 错误如下:

[root@rac1 bin]# ./crsctl check crs

CRS-4638: Oracle High Availability Services is online

CRS-4535: Cannot communicate with Cluster Ready Services

CRS-4529: Cluster Synchronization Services is online

CRS-4533: Event Manager is online

从这个错误提示,可以看到是CRS启动失败了。 CRS是关键进程。 它不能启动,Clusterware 也是启动不了。 导致这个问题的原因很多。

Log 如下:

[root@rac1 rac1]# tail -50 /u01/app/11.2.0/grid/log/rac1/crsd/crsd.log

ORA-15077: could not locate ASM instance serving a required diskgroup

2010-11-16 17:13:44.286: [ OCRASM][3046411024]proprasmo: kgfoCheckMount returned [7]

2010-11-16 17:13:44.286: [ OCRASM][3046411024]proprasmo: The ASM instance is down

2010-11-16 17:13:44.287: [ OCRRAW][3046411024]proprioo: Failed to open [+CRS]. Returned proprasmo() with [26]. Marking location as UNAVAILABLE.

2010-11-16 17:13:44.287: [ OCRRAW][3046411024]proprioo: No OCR/OLR devices are usable

2010-11-16 17:13:44.287: [ OCRASM][3046411024]proprasmcl: asmhandle is NULL

2010-11-16 17:13:44.287: [ OCRRAW][3046411024]proprinit: Could not open raw device

2010-11-16 17:13:44.287: [ OCRASM][3046411024]proprasmcl: asmhandle is NULL

2010-11-16 17:13:44.287: [ OCRAPI][3046411024]a_init:16!: Backend init unsuccessful : [26]

2010-11-16 17:13:44.288: [ CRSOCR][3046411024] OCR context init failure. Error: PROC-26: Error while accessing the physical storage ASM error [SLOS: cat=7, opn=kgfoAl06, dep=15077, loc=kgfokge

ORA-15077: could not locate ASM instance serving a required diskgroup

] [7]

2010-11-16 17:13:44.288: [ CRSD][3046411024][PANIC] CRSD exiting: Could not init OCR, code: 26

2010-11-16 17:13:44.288: [ CRSD][3046411024] Done.

这里的提示是ASM 没有启动造成的。 这里牵涉到的问题较复杂。

这篇文章不打算去具体分析这个问题。 Oracle 官网上有一篇文章对这个问题进行了非常详细的说明。转到了我的Blog。 参考:

How to Troubleshoot Grid Infrastructure Startup Issues [ID 1050908.1]

http://blog.csdn.net/tianlesoftware/archive/2010/11/17/6013763.aspx

In this Document

Goal

Solution

Start up sequence:

Cluster status

Case 1: OHASD.BIN does not start

Case 2: OHASD Agents does not start

Case 3: CSSD.BIN does not start

Case 4: CRSD.BIN does not start

Case 5: GPNPD.BIN does not start

Case 6: Various other daemons does not start

Case 7: CRSD Agents does not start

Network and Naming Resolution Verification

Log File Location, Ownership and Permission

Network Socket File Location, Ownership and Permission

Diagnostic file collection

References

在这里写下我分析问题的思路:

1. 根据log,看能否找到问题的原因。 如果不能清楚的定位问题。 就只能继续分析。

2. 根据CRS 启动的顺序来分析。

在启动的时候,要先启动ASM 实例, 这里牵涉到存储问题。

(1)网络是否正常

(2)存储是否正常的映射到相关的位置, 我的实验采用的是multipath,将存储映射到/dev/mapper/* 目录下。 在遇到问题的时候,会去检查这个问题是否有相关的映射。

(3)存储的权限问题。 因为映射之后,默认是的root用户。 我在/etc/rc.d/rc.local 文件里添加了改变权限的脚本。 开机启动的时候,就将相关映射文件改成Oracle 用户。

3. 如果这些都正常,没有问题, 可以尝试重启CRS 或者重启操作系统。

补充:

在网上还搜索到一个导致CSSD启动失败的原因。 这个我关注的是,它讲到了一个知识点。 讲到了 /tmp/.oracle 和 /var/tmp/.oracle 这两个目录的作用。 每次Server重启的时候,会在这两个文件里存放锁的信息。 当某次重启后,这两个文件不能被删除,就会导致锁不能更新,从而不能启动。

由此也理解了,在删除Clusterware的时候,为什么需要删除这2个目录了。

在RAC 删除的那篇文档里提到了卸载RAC时要删除这2个目录。 参考:

RAC 卸载 说明

http://blog.csdn.net/tianlesoftware/archive/2010/09/18/5892225.aspx

crs.log 日志内容:

2007-04-11 14:37:34.020: [ COMMCRS][1693]clsc_connect: (100f78610) no listener at (ADDRESS=(PROTOCOL=ipc)(KEY=OCSSD_LL_drdb1_crs))

2007-04-11 14:37:34.020: [ CSSCLNT][1]clsssInitNative: connect failed, rc 9

2007-04-11 14:37:34.021: [ CRSRTI][1] CSS is not ready. Received status 3 from CSS. Waiting for good status ..

2007-04-11 14:37:35.740: [ COMMCRS][1695]clsc_connect: (100f78610) no listener at (ADDRESS=(PROTOCOL=ipc)(KEY=OCSSD_LL_drdb1_crs))

2007-04-11 14:37:35.740: [ CSSCLNT][1]clsssInitNative: connect failed, rc 9

When we checked ocssd.log it contained the following

CSSD]2007-04-11 12:53:56.211 [6] >TRACE: clssnmDiskStateChange: state from 2 to 4 disk (0//dev/rdsk/c5t8d0s5)

[ CSSD]2007-04-11 12:53:56.211 [10] >TRACE: clssnmvKillBlockThread: spawned for disk 1 (/dev/rdsk/c5t9d0s5) initial sleep interval (1000)ms

[ CSSD]2007-04-11 12:53:56.211 [11] >TRACE: clssnmvKillBlockThread: spawned for disk 0 (/dev/rdsk/c5t8d0s5) initial sleep interval (1000)ms

[ CSSD]2007-04-11 12:53:56.228 [1] >TRACE: clssnmFatalInit: fatal mode enabled

[ CSSD]2007-04-11 12:53:56.269 [13] >TRACE: clssnmconnect: connecting to node 1, flags 0×0001, connector 1

[ CSSD]2007-04-11 12:53:56.274 [13] >TRACE: clssnmClusterListener: Listening on (ADDRESS=(PROTOCOL=tcp)(HOST=drdb1-priv)(PORT=49895))

[ CSSD]2007-04-11 12:53:56.274 [13] >TRACE: clssnmconnect: connecting to node 0, flags 0×0000, connector 1

[ CSSD]2007-04-11 12:53:56.279 [14] >TRACE: clsclisten: Permission denied for (ADDRESS=(PROTOCOL=ipc)(KEY=Oracle_CSS_LclLstnr_crs_1))

[ CSSD]2007-04-11 12:53:56.279 [14] >ERROR: clssgmclientlsnr: listening failed for (ADDRESS=(PROTOCOL=ipc)(KEY=Oracle_CSS_LclLstnr_crs_1)) (3)

[ CSSD]2007-04-11 12:53:56.279 [14] >TRACE: clssgmclientlsnr: listening on (ADDRESS=(PROTOCOL=ipc)(KEY=Oracle_CSS_LclLstnr_crs_1))

[ CSSD]2007-04-11 12:53:56.279 [14] >TRACE: clssgmclientlsnr: listening on (ADDRESS=(PROTOCOL=ipc)(KEY=OCSSD_LL_drdb1_crs))

[ CSSD]2007-04-11 13:07:36.516 >USER: Oracle Database 10g CSS Release 10.2.0.2.0 Production Copyright 1996, 2004 Oracle. All rights reserved.

[ clsdmt]Fail to listen to (ADDRESS=(PROTOCOL=ipc)(KEY=drdb1DBG_CSSD))

[ CSSD]2007-04-11 13:07:36.516 >USER: CSS daemon log for node drdb1, number 1, in cluster crs

[ clsdmt]Terminating clsdm listening thread

[ CSSD]2007-04-11 13:07:36.536 [1] >TRACE: clssscmain: local-only set to false

[ CSSD]2007-04-11 13:07:36.545 [1] >TRACE: clssnmReadNodeInfo: added node 1 (drdb1) to cluster

[ CSSD]2007-04-11 13:07:36.588 [5] >TRACE: clssnm_skgxnmon: skgxn init failed, rc 1

[ CSSD]2007-04-11 13:07:36.588 [1] >TRACE: clssnm_skgxnonline: Using vacuous skgxn monitor

解决方法:

By checking the above logs we have realised the listener of CSS deamon was unable to start.

the reason why it was unable to start was that each time server reboots it creates a socket at /tmp/.oracle or /var/tmp/.oracle directory .

Also if there are previously existing sockets they cannot be reused or deleted automatically from this directory .oracle.

Therefore the solution to above problem was obtained by deleting all the files inside .oracle directoery in /var/tmp or /tmp.

Hence the crs started and cluster came up.

2


解决:CRS-0184: Cannot communicate with the CRS daemon.

2013-05-09 08:59:09
标签:CRS-0184 oracle
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。/article/4469615.html
早上过来,启动rac ,节点1出现了CRS-0184的错误;

[grid@node1 ~]$ crs_stat -t -v

CRS-0184: Cannot communicate with the CRS daemon.

而节点2都是正常的

网上找到一个比较简单的方法在/tmp/和/var/tmp 下面有个.oracle 的目录,删除掉或许能解决问题;

登录节点1 ,在 /tmp 和/var/tmp 目录下面发现了.oracle 目录,

分别在各自的目录中创建了一个backup 目录,把.oracle 移动到backup目录下面,重启节点1

解决:

mv /var/log/.oracle /var/log/.oracle.bak

重启后正常了

我采用的第二种方法,果然很管用。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: