【Spark】SparkStreaming的容错机制


检查点机制

Metadata checkpointing —— 将定义流计算的信息存入容错的系统如HDFS。
Data checkpointing —— 将产生的RDDs存入可靠的存储空间。代码实现如下图

val sparkContext = new SparkContext(new SparkConf())
val ssc = new StreamingText(sparkContext,duration)

ssc.checkpoint(checkpointDir)	//设置检查点目录

 

驱动器程序容错

就是创建StreamingContext是不要直接new,而是用下面这种方法

val sparkContext = new SparkContext(new SparkConf())
val ssc = StreamingContext.getOrCreate(checkpointDir, createStreamingContext _)

 

工作节点容错

将从外部数据员接收到的数据在多个工作节点备份,根据RDD的Lineage回复丢失的数据
 

接收器容错

就是选择靠谱的数据源。一般都是根据具体的事务情况来选择对应的数据源。比如HDFS、拉式Flume。
 

处理保证

就是尽量选择exactly once模式
我们可以使用事务操作来写入外部系统(即原子化地将一个 RDD 分区一次写入),或者设计幂等的更新操作(即多次运行同一个更新操作 仍生成相同的结果)。比如 Spark Streaming 的 saveAs…File 操作会在一个文件写完时自动 将其原子化地移动到最终位置上,以此确保每个输出文件只存在一份。

posted @ 2020-04-15 12:55  _codeRookie  阅读(543)  评论(0编辑  收藏  举报