栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

Flink状态后端RocksDBStateBackend的使用

Flink状态后端RocksDBStateBackend的使用

第1章 简介

Flink状态和checkpoint的概念这里就不多赘述了,有兴趣的朋友可以看看我之前的文章,直接看一下官方对目前三种StateBackend的对比,在生产环境中我们经常选用的就是RocksDBStateBackend,他有磁盘存储和增量cp的优势,接下来我们就看看开发过程中如何使用RocksDBStateBackend。

名称Working State状态备份快照
RocksDBStateBackend本地磁盘(tmp dir)分布式文件系统全量 / 增量
  • 支持大于内存大小的状态
  • 经验法则:比基于堆的后端慢10倍
FsStateBackendJVM Heap分布式文件系统全量
  • 快速,需要大的堆内存
  • 受限制于 GC
MemoryStateBackendJVM HeapJobManager JVM Heap全量
  • 适用于小状态(本地)的测试和实验

在新版本中有所改动,分为一下两种:

  • HashMapStateBackend:状态数据以 Java 对象的形式存储在堆中。 Key/value 形式的状态;
  • EmbeddedRocksDBStateBackend:将正在运行中的状态数据保存在RocksDB数据库中。

新旧版本使用方法大同小异,下面我们看看具体的使用。 

第2章 全局配置

我们可以在flink-conf.yaml 中进行全局的配置,如果job中有自己的设置,优先job中的设置。

# 用于存储 operator state 快照的 State Backend
state.backend: rocksdb

# 增量
state.backend.incremental: true

# 存储快照的目录
state.checkpoints.dir: hdfs://namenode:40010/flink/checkpoints

第3章 作业中使用

如果要在程序中使用RocksDB作为StateBackend,需要引入如下依赖:


    org.apache.flink
    flink-statebackend-rocksdb_2.11
    1.14.2
    provided

 程序中再进行如下设置:

env.setStateBackend(new RocksDBStateBackend("hdfs://namenode:40010/flink/checkpoints", true));

 checkpoint目录详细说明见:checkpoint目录结构

 更多信息可查阅官方文档:Apache Flink State Backends


2021年就要接近尾声了,时间过的真快,最近一段时间因为工作原因,没有输出文章,今天续上一篇,感恩2021 !!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/682589.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号