GaussDB CN服务异常实例分析
摘要:先通过OPS确认节点状态是否已经恢复,或登录后台执行cm_ctl query -Cv确认集群是否已经Normal。
本文分享自华为云社区《【实例状态】GaussDB CN服务异常》,作者:酷哥。
确认节点状态
先通过OPS确认节点状态是否已经恢复,或登录后台执行cm_ctl query -Cv确认集群是否已经Normal。如果状态已经为normal,表明故障已经恢复,集群正常,不再影响业务。 确认是否需要分析故障的具体原因,如果需要,继续向下跟随文档进行分析 首先确认是否是底层故障如虚拟机故障、网络故障、存储故障,排除底层故障后再继续定位。
定位导图总览

CN进程normal
问题现象
cm_ctl query -Cvd 查询集群状态,告警CN显示normal。

问题分析与定界
step1. 登录告警CN节点,su 进入集群用户,ps ux | grep 'gaussdb --coordinator',查看CN进程启动时间,确认CN是否重启,如果没有重启参考处理方法一(结束),若重启则跳至step2
step2. cd $GAUSSLOG/cm/cm_agent
step3. 打开对应时间点的vi cm_agent-*.log
step4. 查看日志中对应时间点是否含有关键词 cn restart,如果同时有process (gaussdb 17391) is T (STOPPED) 类似日志,说明进程hang住了,跳至step6
step5. 若日志中没有cn restart关键词,查看日志中对应时间点是否含有关键词 CN START.有则跳至step10
step6. 登录到CMS主节点 cd $GAUSSLOG/cm/cm_server
step7. 打开对应时间点的cm_server*.log
step8. 查看日志中对应时间点是否含有关键词 restart %u, there is not report msg for %d sec. 如果有,则CN重启原因为心跳超时,参考处理步骤方法一(结束 )
step9. 查看日志中对应时间点是否含有关键词 phony dead times (%d) already exceeded, will restart...则CN重启原因为进程僵死,参考处理步骤方法一(结束)
step10. cd $GAUSSLOG/cm/cm_agent,打开对应时间点的system_call-*.log,查看对应时间点是否有关键词can not bind ip,如果没有则跳至step12
step11. 如果有关键词can not bind ip,则CN重启原因为CN IP丢失,参考处理步骤方法二 (结束)
step12. cd $GAUSSLOG/pg_log/cn_XX
step13. 查看相关postgresql_xxx.log, 查看相关时间点是否有关键词PANIC,如果有则原因为core,参考处理步骤方法一。
step14. 查看CN数据目录下是否有core生成,如果有则原因为core,参考处理步骤方法一。
step15. 查看$GAUSSLOG/ffic_log日志,查看对应时间点是否有打印日志,如果有则原因为core,参考处理步骤方法一。
处理步骤
方法一:联系华为工程师进行定位
方法二:检查故障节点虚拟IP,浮动IP。如有问题,请排查管控HA是否关闭。
CN进程down
问题现象
cm_ctl query -Cvd 查询集群状态,告警CN显示down。
问题分析与定界
step1. cd $GAUSSLOG/cm/cm_agent
step2. 打开对应时间点的cm_agent-*.log
step3. 查看日志中对应时间点是否含有关键词 cn_disk_damage=1,如果有,则原因为数据/日志磁盘损坏或磁盘满,参考处理步骤方法一。
step4. 查看日志中对应时间点是否含有关键词 port_conflict=1,如果有,则原因为端口冲突,参考处理步骤方法二。
step5. 查看日志中对应时间点是否含有关键词 cn_nic_down=1,如果有,则原因为网卡故障,参考处理步骤方法三。
step6. 查看日志中对应时间点是否含有关键词 cn_manual_stop=1,如果有,则原因为手动停止,参考处理步骤方法四。
处理步骤
方法一:查看对应故障cn的磁盘是否有故障,如无故障则检查是否磁盘满。
方法二:lsof -i:端口号,查看端口占用进程,联系华为工程师定位处理
方法三:联系I层查看是否存在网卡故障
方法四:查看是否有人手动停止
CN进程deleted
问题现象
cm_ctl query -Cvd 查询集群状态,告警CN显示deleted。
问题分析与定界
step1. 确认当时时间故障CN所在节点是否正常,是否主机故障,重启、掉电,断网等,参考处理步骤方法一。
step2. 登入CMS主节点,cd $GAUSSLOG/cm/cm_server,打开对应时间点的cm_server*.log
step3. 如果日志中有关键词isCnDnDisconnected=1, 则原因为CN与所有主DN断连,参考处理步骤方法二。
step4. 如果日志中有关键词cn_down_to_delete=1,则原因为CNdown 导致,参考处理步骤方法三。
step5. 如果日志中有关键词cn instance restarts within ten minutes is more than,则原因为CN进行重启 导致,参考处理步骤方法四。
处理步骤
方法一:联系I层查看主机故障原因,排除故障后,在管控点击节点修复修复cn节点。
方法二:在管控点击[节点修复]修复cn节点,联系华为工程师处理
方法三:在管控点击[节点修复]修复cn节点,参考第二章CN DOWN进行定位
方法四:在管控点击[节点修复]修复cn节点,参考第一章CN NORMAL进行定位
CN进程readonly
问题现象
cm_ctl query -Cvd 查询集群状态,告警CN显示readonly。
问题分析与定界
step1. 登录到只读CN节点后,su - Ruby进入Ruby用户, 执行/usr/sbin/chroot --userspec=Ruby:Ruby /var/chroot 进入沙箱,source /etc/profile设置环境变量
step2. df -h 查看磁盘空间分配情况,cm_ctl query -Cvd查看CN数据目录路径,确认所在磁盘空间使用率。
step3. 登陆cmserver主节点,进入cmserver数据目录/var/chroot/usr/local/cm/cm_server,查看cm_server.conf 配置文件,查看参数datastorage_threshold_value_check的值,当磁盘使用率超过该参数值时,CN就会被设置为只读,避免磁盘被写满。比较CN磁盘使用率是否超过该参数值,如果是,则按照处理步骤1处理,如果否,则按照步骤2处理
处理步骤
1、联系华为工程师,确定是否需要扩容或者删除同磁盘的无用文件
2、参考CN只读处理方法
GaussDB CN服务异常实例分析的更多相关文章
- 5种GaussDB ETCD服务异常实例分析处理
		
摘要:一文带你细数几种ETCD服务异常实例状态. 本文分享自华为云社区<[实例状态]GaussDB ETCD服务异常>,作者:酷哥 . 首先确认是否是虚拟机.网络故障 虚拟机故障导致ETC ...
 - 实例解读丨关于GaussDB ETCD服务异常
		
摘要:本文通过对ETCD服务异常问题分析,代码展示解决方案. 本文分享自华为云社区<[实例状态]GaussDB ETCD服务异常>,作者:酷哥. 首先确认是否是虚拟机.网络故障 虚拟机故障 ...
 - OutOfMemoryError/OOM/内存溢出异常实例分析--虚拟机栈和本地方法栈溢出
		
关于虚拟机栈和本地方法栈,在JVM规范中描述了两种异常: 1.如果线程请求的栈深度大于JVM所允许的深度,将抛出StackOverflowError异常: 2.如果虚拟机在扩展栈时无法申请到足够的内存 ...
 - OutOfMemoryError/OOM/内存溢出异常实例分析--堆内存溢出
		
Java堆内存溢出 只要不断创建对象,并且保证GC Roots到对象之间有可达路径来避免垃圾回收机制清除这些对象, 那么在对象数量到达最大堆的容量限制后就会产生内存溢出异常,代码如下: import ...
 - RPC原理及RPC实例分析
		
在学校期间大家都写过不少程序,比如写个hello world服务类,然后本地调用下,如下所示.这些程序的特点是服务消费方和服务提供方是本地调用关系. 1 2 3 4 5 6 public class ...
 - Netty 拆包粘包和服务启动流程分析
		
Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你能掌握EventLoopGroup的工作流程,ServerBootstrap的启动流程,ChannelPipeline是如何操作管理Ch ...
 - keepalived主备节点都配置vip,vip切换异常案例分析
		
原文地址:http://blog.51cto.com/13599730/2161622 参考地址:https://blog.csdn.net/qq_14940627/article/details/7 ...
 - 【转】Netty 拆包粘包和服务启动流程分析
		
原文:https://www.cnblogs.com/itdragon/archive/2018/01/29/8365694.html Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你 ...
 - RPC-原理及RPC实例分析
		
还有就是:RPC支持的BIO,NIO的理解 (1)BIO: Blocking IO;同步阻塞: (2)NIO:Non-Blocking IO, 同步非阻塞; 参考:IO多路复用,同步,异步,阻塞和非阻 ...
 - RPC原理及RPC实例分析(转)
		
出处:https://my.oschina.net/hosee/blog/711632 在学校期间大家都写过不少程序,比如写个hello world服务类,然后本地调用下,如下所示.这些程序的特点是服 ...
 
随机推荐
- 数据类型python
			
type()语句的用法 运行结果
 - PTA乙级1099
			
#include"bits/stdc++.h" using namespace std; int prime(int x) { if(x<2) return 0; for(i ...
 - spring---反射(java.lang.reflect)
			
反射简介 反射是Java的高级特性之一,但是在实际的开发中,使用Java反射的案例却非常的少,但是反射确实在底层框架中被频繁的使用. 比如:JDBC中的加载数据库驱动程序,Spring框架中加载bea ...
 - 用原型实现Class的各项语法
			
本人之前对Class一直不够重视.平时对原型的使用,也仅限于在构造函数的prototype上挂属性.原型尚且用不着,更何况你Class只是原型的一颗语法糖? 直到公司开始了一个webgis项目,使用o ...
 - 03Java学习_注释和代码规范
			
注释和代码规范 目录 注释和代码规范 注释 注释介绍 单行注释 多行注释 文档注释 代码规范 注释 注释介绍 用于注解说明解释程序的文字就是注释,注释提高了代码的阅读性(可读性):注释 是一个程序员必 ...
 - 下载神器——you-get
			
下载神器--you-get 01. you-get下载 you-get是一个基于Python3开发的开源项目. 某些网站的音视频资源,本身不提供下载功能,通过you-get,可以通过几条简单的命令去下 ...
 - CH59x 系统16位PWM使用
			
以下使用CH592X做验证 CH59X系列相对于CH58X,CH57X系列的8位系统PWM多了6路的16位的PWM. CH59X除了定时器提供的 4 路 26 位 PWM 输出之外,系统还提供了 8 ...
 - [USACO2007FEB S]Silver Lilypad Pond
			
题目描述 为了让奶牛们娱乐和锻炼,农夫约翰建造了一个美丽的池塘.这个长方形的池子被分成 了M行N列个方格(1 ≤ M, N ≤ 30).一些格子是坚固得令人惊讶的莲花,还有一些格子是 岩石,其余的只是 ...
 - ssm整合-项目异常处理方案
			
项目异常分类: 项目异常处理方案: 需要自定义异常处理 然后在处理器中加入 package com.itheima.controller; import com.itheima.exception.B ...
 - 聊一聊 .NET高级调试 内核模式堆泄露
			
一:背景 1. 讲故事 前几天有位朋友找到我,说他的机器内存在不断的上涨,但在任务管理器中查不出是哪个进程吃的内存,特别奇怪,截图如下: 在我的分析旅程中都是用户态模式的内存泄漏,像上图中的异常征兆已 ...