1. DataStream Source

    • 基于文件

      • readTextFile(path)

        • 读取 text 文件的数据
      • readFile(fileInputFormat, path)
        • 通过自定义的读取方式, 来读取文件的数据
    • 基于socket

      • socketTextStream

        • 从 socket 端口中读取数据
    • 基于集合

      • fromCollection(Collection)

        • 从 collection集合中读取数据, 从而形成一个数据流, 集合中的元素类型需要一致
      • fromElements(T ...)
        • 从数组里读取数据, 从而形成一个数据流, 集合中的元素类型需要一致。
    • 自定义 source

      • addSource - 自定义一个数据源,比如FlinkKafkaConsumer,从kafka里读数据。
  2. DataStream Transformations

    转换算子 描述
    Map DataStream --> DataStream 采用一个元素并生成一个元素
    FlatMap DataStream --> DataStream 一个元素并生成零个, 一个或多个元素
    Filter DataStream --> DataStream 过滤函数返回 false 的数据, true 的数据保留
    KeyBy DataStream --> KeyedStream 指定 key将 K, V 格式的数据流进行逻辑分区, 将相同 key 的记录分在同一分区中。
    Aggregations KeyedStream --> DataStream 对k,v格式的数据流进行聚合操作。
    Reduce KeyedStream --> DataStream 对k,v的数据进行“减少操作”,这个操作逻辑自己写,加减乘除都行
  3. DataStream Sink

    • writeAsText()

      • 将计算结果输出成text文件
    • writeAsCsv()
      • 将计算结果输出成csv文件
    • print()
      • 将计算结果打印到控制台
    • writeUsingOutputFormat()
      • 自定义输出方式
    • writeToSocket
      • 将计算结果输出到某台机器的端口上。
  4. DataType

    • Flink对DataSet或DataStream中可以包含的元素类型设置了一些限制。

    • 它支持多种不同类别的数据类型:

      • Java Tuples and Scala Case Classes
      • JAVA POJOs
      • Primitive Types
    • Java Tuples and Scala Case Classes

    • POJO

      • 如果满足以下要求,则Flink将Java和Scala类视为特殊的POJO数据类型:

        • 必须是public class
        • 必须有一个无参构造器(默认构造函数)
        • 所有字段都是public的,或者必须通过getter和setter函数访问。
        • 对于一个名为foo的字段getter和setter方法的字段必须命名getFoo()和setFoo()。
        • 成员属性的类型必须是Flink支持的数据类型。目前,Flink使用Avro序列化任意对象(例如Date)。
    • Primitive Types(原始类型)

      • Flink支持所有Java和Scala的原始类型,如Integer,String和Double。

Flink笔记(二) DataStream Operator(数据流操作)的更多相关文章

  1. jQuery学习笔记(二)jQuery中DOM操作

    目录 DOM操作分类 jQuery中的各种DOM操作 查找节点 创建节点 删除节点 复制节点 替换节点 包裹节点 属性操作 样式操作 对HTML.文本和值的操作 遍历节点 CSS-DOM操作 小结 本 ...

  2. python笔记二(mysql数据库操作)

    python2.x使用MySQLdb python3.x使用pymysql代替MySQLdb 不过我使用的是python3.5,MySQLdb还是可以在python3.5使用的. #!/usr/bin ...

  3. python笔记二:常用数据类型操作

    1.切片:常用于取list或tuple的部分元素的操作 1)l=[1,2,3,4,5,6] l[:3]表示取前3个值,l[1:5]表示1到5个值, L[-3:]从列表最后往前数即最后3个数.... 2 ...

  4. python3笔记二十一:时间操作datetime和calendar

    一:学习内容 datetime calendar 二:datetime 1.模块说明:可以理解为datetime基于time进行了封装,提供了各种使用的函数,datetime模块的接口更直接,更容易调 ...

  5. python3笔记二十:时间操作time

    一:学习内容 time时间戳 time元组 time字符串 time时间转换图解 二:time 需要引入:import time 1.概念 UTC(世界协调时间):格林尼治天文时间,世界标准时间,在中 ...

  6. jquery学习笔记(二):DOM元素操作

    内容来自[汇智网]jquery学习课程 2.1 元素属性操作 1.获取元素的属性 语法:attr(name) 参数name表示属性的名称 2.设置元素的属性 单个属性设置语法:attr(key,val ...

  7. python学习笔记(二)---for循环与操作列表

    内容概要 for循环 range(start,end,step)函数 生成随机数列表 list()函数 将range()的结果整合到某个列表 列表的操作 切片(start: end :step) 元组 ...

  8. Flink流处理(三)- 数据流操作

    3. 数据流操作 流处理引擎一般会提供一组内置的操作,用于对流做消费.转换,以及输出.接下来我们介绍一下最常见的流操作. 操作分为无状态的(stateless)与有状态的(stateful).无状态的 ...

  9. git的学习笔记(二):git远程操作

    1.创建ssh key ssh-keygen -t rsa -C "your_email@example.com" 执行命令后会在用户的家目录生成.ssh的隐藏文件夹,文件夹里有公 ...

随机推荐

  1. Numpy 为运算

    Numpy “bitwise_” 开头的函数是位运算函数: Numpy 位运算包括以下几个函数: 函数 描述  bitwise_and  对数组元素执行位与操作  bitwise_or 对数组元素执行 ...

  2. 吴裕雄--天生自然PYTHON爬虫:使用BeautifulSoup解析中国旅游网页数据

    import requests from bs4 import BeautifulSoup url = "http://www.cntour.cn/" strhtml = requ ...

  3. ZB本地设置

    (1)web.config <!--本地服务器--> <add name="connectionString" connectionString="mG ...

  4. container-coding-codec

    1 数字容器格式 container format 1.1 一些音频专有的容器: 1.2 静态图像专用的容器: 1.3 视频容器,可以容纳多种类型的音频和视频以及其他媒体 1.4 视频容器格式概述 1 ...

  5. JavaScript(3)---事件冒泡、事件捕获

    JavaScript(3)---事件冒泡与事件捕获 一.理解冒泡与捕获 假设有这么一段代码 <body> <div><p>标签</p> </div ...

  6. Windows上设置Sass

    现在有很多信息在预处理器上浮动.大部分信息都面向Mac用户,所以在这篇文章中,我提供了一个非常简单的指南,帮助基于Windows的开发人员快速启动并运行Sass(我选择的预处理器). 本文是在此博客上 ...

  7. 我的Grunt之旅-序章

    时间:2018-03-05 13:52  事件:安装Grunt 相关网址: grunt官网:https://gruntjs.com node.js下载地址 :https://nodejs.org/en ...

  8. Java笔记--常用类

    1.String类: --使用Unicode字符编码,一个字符占两个字节: --String类是一个final类,代表不可变的字符序列: --字符串是不可变的,一个字符串对象一旦被配置,其内容是不可变 ...

  9. 整理jvm概念和原理详解以及gc机制

    注:源代码就是.java文件,JVM字节码就是.class文件 1. Java 堆(Java Heap):(1)是Java虚拟机所管理的内存中最大的一块.(2)在虚拟机启动的时候创建.堆是jvm所有线 ...

  10. dataGridView与数据源dataTable同步排序

    private void dataGridView1_Sorted(object sender, EventArgs e)         {             string _sortStr ...