您当前的位置:首页 > 电脑百科 > 数据库 > Oracle

oracle rac问题排查思路

时间:2020-12-29 13:48:04  来源:  作者:

当oracle rac出问题时,很多人往往不知道从何查起,我根据自己在生产上排查的经验,说一下自己的排查思路。

一、查看系统时间是否同步

1、date

2、不同步的进行同步,在两个节点上执行:

ntpdate -u 1.cn.pool.ntp.org

3、重启有问题的节点

【时间不同步,断电后数据库启动时crs启动失败导致asm启动失败,最后数据库启动失败,asm日志信息报i/o错误、找不到磁盘组等,可能会误导问题的定位,其实只是时间不同步导致的问题,找到问题的根源,重启即可】

二、查看防火墙是否关闭

ping 私有ip,vip,如果不通,先按下面步骤操作:

1、 查看防火墙状态:service iptables status

2、 如果防火墙是开的,就关闭:service iptables stop

3、 设置防火墙不要开机启动:chkconfig iptables off

4、 检查上一步是否设置成功:chkconfig --list iptables

oracle rac问题排查思路

关闭防火墙

重启有问题节点数据库即可。

三、查看归档日志空间情况

归档日志满的话会导致数据库异常,删除过期日志可解决。

1、 进入grid 用户,asmcmd,输入lsdg查看磁盘情况,删除前和删除后做个对比,就知道腾出多少空间了:

su – grid

asmcmd

lsdg

oracle rac问题排查思路

 

2、 用rman来删除,不要手动删除

su – oracle

rman target /

crosscheck archivelog all;//检查控制文件和实际物理文件的差别。

//删除7天前日志

delete noprompt archivelog all completed before 'sysdate-7';

//将过期的日志删除:

delete noprompt expired archivelog all;

delete noprompt obsolete【或者delete noprompt obsolete until time 'sysdate-7' ;

到这里,归档删除完了

3、 查看腾出多少空间,如果腾出的空间还不够,在ASM管理模式下手工删除方法:【有双实例的,每个实例都进去检查一下是否有过期归档日志】

ASMCMD>cd archivelog

ASMCMD>ls

(ASMCMD>rm -f +data/zgdb/archivelog/2013_10_31/t* 删除2013年10月31日的归档日志)

ASMCMD>rm –rf ./2016* 删除所有2016年文件夹及文件夹下的归档日志文件

oracle rac问题排查思路

手动删除日志

把归档日志物理文件删除后,但是还没完全把归档日志删除干净,需要检验同步。登录rman,执行如命令:

su - oracle

rman target /

RMAN> crosscheck archivelog all;

RMAN>delete expired archivelog all;

【补充】

查询每天的归档产生的情况:

SELECT TRUNC(FIRST_TIME) "TIME",SUM(BLOCK_SIZE * BLOCKS) / 1024 / 1024 / 1024 "SIZE(GB)"FROM V$ARCHIVED_LOG GROUP BY TRUNC(FIRST_TIME);

oracle rac问题排查思路

查询每天的归档产生的情况

查询最近7天每天归档产生情况,在上条sql中加过滤条件:

SELECT TRUNC(FIRST_TIME) "TIME",SUM(BLOCK_SIZE * BLOCKS) / 1024 / 1024 / 1024 "SIZE(GB)"FROM V$ARCHIVED_LOG GROUP BY TRUNC(FIRST_TIME) having TRUNC(FIRST_TIME) >= TRUNC(sysdate -7);

四、查看crs状态及日志

1、使用系统命令查看相关进程

ps –ef | grep d.bin

oracle rac问题排查思路

 

2、使用oracle命令查看集群状态

进入oracle 的bin目录下:

cd /u01/App/11.2.0/grid/bin/

执行:

./crsctl stat res -t

oracle rac问题排查思路

 

或者,进入grid用户,直接执行crsctl stat res -t

3、在每个节点上检查crs状态

[grid@rac1 ~]$ crsctl check cluster

oracle rac问题排查思路

节点1


oracle rac问题排查思路

节点2

crsctl check crs //只检查本节点

oracle rac问题排查思路

 

4、crs日志路径

Grid相关日志:

/u01/app/11.2.0/grid/log/node1

5、启动某个节点crs【使用root用户执行】

./crsctl start cluster -n db1 //-n后是节点名

五、查看asm状态及日志

1、检查 ASM状态及配置

[oracle@rac1 ~]$ srvctl status asm

ASM is running on rac1,rac2

oracle rac问题排查思路

 

2、asm日志路径

Asm相关日志路径:

/u01/app/grid/diag/asm/+asm/+ASM1/trace

重要的日志文件:alert_+ASM1.log

3、查询asm配置

srvctl config asm -a

oracle rac问题排查思路

 

4、启动asm实例【最好在grid用户下执行】

srvctl start asm -n db1 // -n后是节点名字

 

还有其他检查,像检查节点应用状态及配置、查看数据库配置、检查scan ip、检查 VIP的状态及配置等,篇幅原因就先不再介绍了。可以关注我,如果以后遇到oracle rac故障需要排查,我们可以进行沟通交流。



Tags:oracle   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  Tags: oracle  点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  Tags: oracle  点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  Tags: oracle  点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Tags: oracle  点击:(88)  评论:(0)  加入收藏
2021年免费vps服务器申请,oracle永久免费使用。Oracle 云免费套餐只需注册 Oracle 云帐户即可获取,不仅包含丰富的 Always Free 云服务,还提供 300 美元的免费试用储值,让您可以...【详细内容】
2021-09-08  Tags: oracle  点击:(109)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  Tags: oracle  点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  Tags: oracle  点击:(87)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  Tags: oracle  点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity('河北沧州东塑股份有限公司','河北沧州东...【详细内容】
2021-07-07  Tags: oracle  点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  Tags: oracle  点击:(103)  评论:(0)  加入收藏
▌简易百科推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  守护梦想2022    Tags:Oracle   点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  JasonTang    Tags:Oracle   点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  it运维小土豆  今日头条  Tags:Oracle   点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Java技术栈  掘金  Tags:Oracle   点击:(88)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  free教程    Tags:Oracle日志   点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  大树唛包    Tags:oracle   点击:(87)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  死磕IT    Tags:Oracle rac   点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity('河北沧州东塑股份有限公司','河北沧州东...【详细内容】
2021-07-07  Onceagain75783189    Tags:比较函数   点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  程序猿集锦    Tags:Oracle   点击:(103)  评论:(0)  加入收藏
oarcle数据库真正存放数据的是数据文件(data files),Oarcle表空间(tablespaces)实际上是一个逻辑的概念,他在物理上是并不存在的,那么把一组data files 捻在一起就成为一个表空间。...【详细内容】
2021-04-27  SQL小帅哥  今日头条  Tags:Oracle   点击:(198)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条