一切新知识的学习,都离不开官网得相关阅读,那么StreamingFileSink的官网介绍呢?

https://ci.apache.org/projects/flink/flink-docs-release-1.10/zh/dev/connectors/streamfile_sink.html

flink在被阿里收购之后,官网也有了相当多的中文文档,英文不好的同学可以直接看中文版的,不过还是建议时间充足的同学直接阅读英文文档,毕竟现在的chrome中的划词翻译很是方便了,哪里不会点哪里,慢慢的开发中常见词汇也就能看个大概了。

1. 写出文件的状态

看这个图片应该能明白,文件会分在不同的桶中,bucket中存在不同状态的文件:

  1. In-progress :当前文件正在写入中
  2. Pending :当处于 In-progress 状态的文件关闭(closed)了,就变为 Pending 状态
  3. Finished :在成功的 Checkpoint 后,Pending 状态将变为 Finished 状态

2. 简单的字符串写出示例

  1. DataStreamSource<String> lines = FlinkUtil.createSocketStream("localhost", 8888);
  2. StreamExecutionEnvironment env = FlinkUtil.getEnv();
  3. // 设置checkpoint
  4. env.enableCheckpointing(TimeUnit.SECONDS.toMillis(10));
  5. OutputFileConfig config = OutputFileConfig
  6. .builder()
  7. .withPartPrefix("prefix")
  8. .withPartSuffix(".txt")
  9. .build();
  10. final StreamingFileSink<String> sink = StreamingFileSink
  11. .forRowFormat(new Path(outputPath), new SimpleStringEncoder<String>("UTF-8"))
  12. /**
  13. * 设置桶分配政策
  14. * DateTimeBucketAssigner--默认的桶分配政策,默认基于时间的分配器,每小时产生一个桶,格式如下yyyy-MM-dd--HH
  15. * BasePathBucketAssigner :将所有部分文件(part file)存储在基本路径中的分配器(单个全局桶)
  16. */
  17. .withBucketAssigner(new DateTimeBucketAssigner<>())
  18. /**
  19. * 有三种滚动政策
  20. * CheckpointRollingPolicy
  21. * DefaultRollingPolicy
  22. * OnCheckpointRollingPolicy
  23. */
  24. .withRollingPolicy(
  25. /**
  26. * 滚动策略决定了写出文件的状态变化过程
  27. * 1. In-progress :当前文件正在写入中
  28. * 2. Pending :当处于 In-progress 状态的文件关闭(closed)了,就变为 Pending 状态
  29. * 3. Finished :在成功的 Checkpoint 后,Pending 状态将变为 Finished 状态
  30. *
  31. * 观察到的现象
  32. * 1.会根据本地时间和时区,先创建桶目录
  33. * 2.文件名称规则:part-<subtaskIndex>-<partFileIndex>
  34. * 3.在macos中默认不显示隐藏文件,需要显示隐藏文件才能看到处于In-progress和Pending状态的文件,因为文件是按照.开头命名的
  35. *
  36. */
  37. DefaultRollingPolicy.builder()
  38. .withRolloverInterval(TimeUnit.SECONDS.toMillis(2)) //设置滚动间隔
  39. .withInactivityInterval(TimeUnit.SECONDS.toMillis(1)) //设置不活动时间间隔
  40. .withMaxPartSize(1024 * 1024 * 1024) // 最大零件尺寸
  41. .build())
  42. .withOutputFileConfig(config)
  43. .build();
  44. lines.addSink(sink).setParallelism(1);

3. 写出文件的滚动策略

数据写入文件时,查看源码可以知道

滚动策略是这么判断的:

没有处于inProgressPart状态的文件 或者 DefaultRollingPolicy.shouldRollOnEvent成立,即打开的文件大小超过了滚动器中设置的大小

滚动文件时,首先关闭当前处于progress的part文件,然后创建一个新的 assembleNewPartPath,并且partCounter++(计数器)

StreamingFileSink继承自RichSinkFunction,显然之后执行一次,

该方法中注册了一个定时器,定时器的执行时间为currentProcessingTime + bucketCheckInterval

其中bucketCheckInterval为调用StreamingFileSink.forRowFormat()时,默认创建的,其默认值为60000,也就是一分钟

onProcessingTime方法继承自ProcessingTimeCallback,此方法使用调度触发器的时间戳调用。

该方法中设定了60秒的定时器,定时每60秒执行一次该方法

该方法中会调用buckets.onProcessingTime(currentTime)

里面判断是否需要关闭part文件,注意是关闭而不是滚动

判断条件为:part文件不为空 并且 DefaultRollingPolicy.shouldRollOnProcessingTime条件成立

即part文件存在,并且 (当前时间-part的创建时间 >= 滚动时间 或者 当前时间-part的最后修改时间 >= 不活跃时间)

snapshotState和initializeState方法继承自CheckpointedFunction,用来构建快照或者恢复历史状态

其中snapshotState方法会调用buckets.snapshotState()方法,对桶的状态进行快照处理

将所有处理活跃状态的桶全部进行快照处理,做快照时会检查是否需要滚动,滚动条件为:

part文件不为空 并且 DefaultRollingPolicy.shouldRollOnCheckpoint成立,即文件大小超过设定

满足该条件时,就会关闭partFile

notifyCheckpointComplete方法继承自CheckpointListener,用来通知检查点完成

该方法中会调用onSuccessfulCompletionOfCheckpoint方法

会将已经关闭的(其实是处于Pending状态的文件)part文件重命名

Flink-1.10中的StreamingFileSink相关特性的更多相关文章

  1. LINQ系列:C#中与LINQ相关特性

    1. 匿名类型 通过关键字var定义匿名类型,编译器将根据运算符右侧表达式的值来发出一个强类型. 使用匿名类型时要遵守的一些基本规则: ◊ 匿名类型必须有一个初始化值,而且这个值不能是空值(null) ...

  2. Linux 4.10中两个新特性与我的一段故事

    今早5点半起来没有開始写文章,而是去西湾红树林连跑带走折腾了将近20公里.回来后就8点多了...洗了个澡之后坐稳当.開始写一段关于我的故事.        在2014年到2015年期间,我在负责研发一 ...

  3. [ES6系列-03]ES6中关于参数相关特性详解(参数默认值与参数解构赋值与剩余参数)

    [原创] 码路工人 大家好,这里是码路工人有力量,我是码路工人,你们是力量. 今天总结一下 ES6 中跟参数相关的内容. 欢迎补充斧正.留言交流. 让我们互相学习一起进步. 1. ES6 参数默认值( ...

  4. C#中的自定义控件中的属性、事件及一些相关特性的总结(转)

      摘要: C#中的自定义控件中的属性(Property).事件(Event)及一些相关特性(Attribute)的总结 今天学习了下C#用户控件开发添加自定义属性的事件,主要参考了MSDN,总结并实 ...

  5. TCP/IP协议栈源码图解分析系列10:linux内核协议栈中对于socket相关API的实现

    题记:本系列文章的目的是抛开书本从Linux内核源代码的角度详细分析TCP/IP协议栈内核相关技术 轻松搞定TCP/IP协议栈,原创文章欢迎交流, byhankswang@gmail.com linu ...

  6. linux中Makefile文件相关内容

    第一章.概述什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional(专业)的程序员,m ...

  7. 关于 iOS 10 中 ATS 的问题

    本文于 2016 年 11 月 28 日按照 Apple 最新的文档和 Xcode 8 中的表现进行了部分更新. WWDC 15 提出的 ATS (App Transport Security) 是 ...

  8. Linux中exec命令相关

    Linux中exec命令相关 exec和source都属于bash内部命令(builtins commands),在bash下输入man exec或man source可以查看所有的内部命令信息. b ...

  9. 关于 iOS 10 中 ATS / HTTPS /2017 问题

    本文于 2016 年 11 月 28 日按照 Apple 最新的文档和 Xcode 8 中的表现进行了部分更新. WWDC 15 提出的 ATS (App Transport Security) 是 ...

随机推荐

  1. MapReduce之WritableComparable排序

    @ 目录 排序概述 获取Mapper输出的key的比较器(源码) 案例实操(区内排序) 自定义排序器,使用降序 排序概述 排序是MapReduce框架中最重要的操作之一. Map Task和Reduc ...

  2. python基础day4_列表list

    list列表 li = ['alex',[1,2,3],'hjh','nvshen '] l1= li[0] print(l1) # alex l3= li[0:3]#['alex', [1, 2, ...

  3. PHP time_nanosleep() 函数

    实例 延迟执行当前脚本 3,5 秒: <?phpif (time_nanosleep(3,500000000) === true){高佣联盟 www.cgewang.comecho " ...

  4. 使用jsdelivr + GitHub + PicGo搭建免费图床

    前言 之前一直有开通有道云笔记会员,主要是为了会员markdown图片可以在线保存的功能,前一阵子会员到期,考虑这个功能可不可以自己单独实现,从而替代使用有道云会员. 通过网上搜索的方式,查询到了几种 ...

  5. 付费?是不可能的!20行Python代码实现一款永久免费PDF编辑工具

    PDF(Portable Document Format),中文名称便携文档格式是我们经常会接触到的一种文件格式,文献.文档…很多都是PDF格式.它以格式稳定的优势,使得我们在打印.分享.传输过程中能 ...

  6. 分享一个内网穿透工具frp

    首先简单介绍一下内网穿透: 内网穿透:通过公网,访问局域网里的IP地址与端口,这需要将局域网里的电脑端口映射到公网的端口上:这就需要用到反向代理,即在公网服务器上必须运行一个服务程序,然后在局域网中需 ...

  7. SpringMVC 集成 JWT验证方式

    JWT官网: https://jwt.io/ 这里以java的ssm框架为例,集成jwt. 1.pom.xml 导入jwt的包 <!-- jwt --> <dependency> ...

  8. CNN 小结

    CNN 小结 目录 CNN特征提取过程(卷积核描述的是特征信息, 此特征可能就是原图像中的某些像素, 但是卷积核并不找相似的地方在原始图像的哪里, 所以需要将卷积核不断地滑动, 得到的feature ...

  9. Java常用类:包装类,String,日期类,Math,File,枚举类

    Java常用类:包装类,String,日期类,Math,File,枚举类

  10. 《Java核心技术(卷1)》笔记:第12章 并发

    线程 (P 552)多进程和多线程的本质区别:每一个进程都拥有自己的一整套变量,而线程共享数据 (P 555)线程具有6种状态: New(新建):使用new操作符创建线程时 Runnable(可运行) ...