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

Flink 系例 之 KeyBy

Flink 系例 之 KeyBy

KeyBy算子:将数据流按照指定key进行分区(分组)

示例环境

java.version: 1.8.x
flink.version: 1.11.1

 示例数据源 (项目码云下载)

Flink 系例 之 搭建开发环境与数据

KeyBy.java

package com.flink.examples.functions;

import com.flink.examples.DataSource;
import org.apache.flink.api.java.functions.KeySelector;
import org.apache.flink.api.java.tuple.Tuple3;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.datastream.KeyedStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import java.util.List;


public class KeyBy {

    
    public static void main(String[] args) throws Exception {
        final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        //如果有多个分区,则设置并行度需大于1,或者在算子上设置setParallelism(2)前行度,否则算子只有一个并行度,则计算结果始终只有一个分区
//        env.setParallelism(4);
        List> tuple3List = DataSource.getTuple3ToList();
        DataStream> dataStream = env.fromCollection(tuple3List);
        //注意:使用Integer进行分区时,会导致分区结果不对,转换成String类型输出key即可正确输出
        KeyedStream, String> keyedStream = dataStream.keyBy(new KeySelector, String>() {
            @Override
            public String getKey(Tuple3 tuple3) throws Exception {
                //f1为性别字段,以相同f1值(性别)进行分区
                return String.valueOf(tuple3.f1);
            }
        });

        //lambda
//        KeyedStream, String> keyedStream = dataStream.keyBy((KeySelector, String>) t3 -> t3.f1);
        //指定第几个字段做为key进行计算
//        KeyedStream, Tuple> keyedStream = dataStream.keyBy(1);
        keyedStream.print().setParallelism(4);
        env.execute("flink keyBy job");
    }
}

打印结果

2> (张三,man,20)
4> (李四,girl,24)
2> (王五,man,29)
4> (刘六,girl,32)
2> (吴八,man,30)
4> (伍七,girl,18)
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/582124.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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