Flink 的HelloWorld

1.Flink读取Text文件,实现Word Count示例

package com.mkluo.flink
import org.apache.flink.api.scala.ExecutionEnvironment

/**
  * @author luomingkui
  * @date 2019/7/7 下午2:44
  * @desc 批处理的WorldCount
  */
object BatchWcApp {

  def main(args: Array[String]): Unit = {

    //1.构造执行环境

   val env = ExecutionEnvironment.getExecutionEnvironment

    // 其中flatMap 和Map 需要引入隐式转换
    import org.apache.flink.api.scala._

    //2.source
    val ds: DataSet[String] = env.readTextFile("/Users/luomingkui/Downloads/CaseData/test/helloworlds.txt")

    //3.经过groupby进行分组,sum进行聚合
    val aggDs: AggregateDataSet[(String, Int)] = ds.flatMap(_.split(" ")).map((_, 1)).groupBy(0).sum(1)

    //4.打印
    aggDs.print()

    //4.输出到?点地点
    aggDs.writeAsCsv("/Users/luomingkui/Downloads/data")
    env.execute()


  }
}

 

2.Flink读取Socket流,实现Word Count示例

package com.mkluo.flink
import org.apache.flink.streaming.api.scala.{DataStream, StreamExecutionEnvironment}
/**
  * @author luomingkui
  * @date 2019/7/7 下午4:36
  * @desc 流处理的WorldCount
  */
object StreamWcApp {

  def main(args: Array[String]): Unit = {

    //从外部命令中获取参数
    //val tool: ParameterTool = ParameterTool.fromArgs(args)

    //val host: String = tool.get("hadoop102")
    //val port: Int = tool.get("7777").toInt


    //创建流处理环境
    val env: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment

    // 设置并行度
    env.setParallelism(2)

    //接收socket文本流
    val textDstream: DataStream[String] = env.socketTextStream("hadoop102",7777)

    // flatMap和Map需要引用的隐式转换
    import org.apache.flink.api.scala._

    //处理 分组并且sum聚合
    val dStream: DataStream[(String, Int)] = textDstream.flatMap(_.split(" ")).filter(_.nonEmpty).map((_,1)).keyBy(0).sum(1)


    //打印
    dStream.print()

    env.execute()
  }
}

    • 测试:在linux系统中用 nc -lk  7777 进行发送测试

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员学习圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值