flink算子之sink算子

sink算子: 把计算之后的最终结果写入到某个位置

1.文件

1)writeAsText/ writeAsCsv

弃用的方法,但是可以使用

如果并行度为1,直接以一个文件的形式体现,内容是追加的,因为设置了并行度env.setParallelism(1)

如果并行度大于1,以一个目录的形式出现,并行度是几就有几个文件,不设置并行度时,CPU的核数为并行度数目

dataStreamOriginal.writeAsText("E://path")

2) addSink(StreamingFileSink)

StreamingFileSink.forRowFormat获取内部类RowFormatBuilder的对象,内部类RowFormatBuilder的对象调用build()获取到单利SimpleStringEncoder

目前建议使用的方法,不管并行度是多少,都以目录形式出现

dataStreamOriginal.addSink(StreamingFileSink.forRowFormat(
    new Path("E://path"),
    new SimpleStringEncoder[SensorReading]()
 ).build()

 

/**
   * 把结果写入到文件,下沉到sink
   * @param dataStreamOriginal
   */
  def sink_File(dataStreamOriginal: DataStream[SensorReading]): Unit ={
    //文件:E://path 只有一个分区,因为设置了并行度env.setParallelism(1)
    //不设置并行度时,CPU的核数为并行度数目,此时路径为目录级别,文件数为CPU核数
    //分区:则是以目录形式,每一个分区产生一个文件

    //被弃用的写入文件的方法
    dataStreamOriginal.writeAsText("E://path")
    //dataStreamOriginal.writeAsCsv()

    //官方建议我们写入文件使用的方法
    dataStreamOriginal.addSink(
      //StreamingFileSink.forRowFormat获取内部类RowFormatBuilder的对象
      //内部类RowFormatBuilder的对象调用build()获取到单利SimpleSt
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值