Author: 康贤
FTS(Fault Tolerance Serve)是GreenPlum中的故障检测服务,是保证GP高可用的核心功能。GreenPlum的Segment的健康检测及HA是由GP Master实现的,GP Master上面有个专门的进程–FTS进程,它可以快速检测到Primary或者Mirror是否挂掉,并及时作出Primary/Mirror 故障切换。如果FTS挂掉了,Master将会重新fork出来一个FTS进程。
GP Master上面的FTS进程每隔60s(时间可以配置)向Primary或者Mirror发送心跳包,Primary和Mirror收到心跳包后返回它们的当前状态,FTS进程心跳包的发送状态和Segment返回状态更新元信息和作出故障切换。因为Segment可能很多,为了加快检测速度,FTS是多线程的,默认16个线程。
实现检测方法的源码大致如下:
while (!probeGetIpAddr(&probeInfo) ||
!probeOpenSocket(&probeInfo) ||
!probeMarkSocketNonBlocking(&probeInfo) ||
!probeConnect(&probeInfo) ||
!probeSend(&probeInfo) ||
!probeReceive(&probeInfo) ||
!probeProcessResponse(&probeInfo))
{
probeClose(&probeInfo);
if (retryCnt == gp_fts_probe_retries)
{
write_log("FTS: failed to probe segment (content=%d, dbid=%d) after trying %d time(s), "
"maximum number of retries reached.",
probeInfo.segmentId,
probeInfo.dbId,
retryCnt);
break;
}
/* sleep for 1 second to avoid tight loops */
pg_usleep(USECS_PER_SEC);
retryCnt++;
//other code
}
GP Master首先会检测Primary状态,如果Primary不可连通,那么将会检测Mirror状态,Primary/Mirror状态总共有4种:
用来故障检测的线程数量,默认为16。
两次检测的时间间隔,默认为60s。如果一次检测时间使用10s,那么剩余50s将会sleep;如果超过60s,将会直接进入下一次检测。
检测Segment超时时间,默认值: 20。
检测Segment失败重试次数,如果超过这个次数,将会认为当前节点挂掉,默认值: 5。
Prmary和Mirror文件同步允许连接Mirror最大超时时间,如果达到这个超时时间,Primary将会认为Mirror挂掉了,默认值: 180s。
通过GreenPlum FTS机制学习,可以了解部分MPP架构高可用原理。同时根据自身的业务,合理地配置FTS参数,保障GP高可用。