热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

FlinkDataStreamJoin小规模维度数据的简便方法

在编写基于Flink的ETL程序时,我们经常需要用维度数据丰富我们接入的流式数据,如通过商品ID获得商品名称、通过商品分类ID获得分类名称等等。而维度表

在编写基于Flink的ETL程序时,我们经常需要用维度数据丰富我们接入的流式数据,如通过商品ID获得商品名称、通过商品分类ID获得分类名称等等。而维度表基本都位于外部存储,换句话说,就是要解决一个无界的流式表与一个有界的码表或半静态表做join操作的问题。

一般情况下的首选方案是Flink内置的异步I/O机制,必要时还得配合使用高效的缓存(如Guava提供的LoadingCache)减少对外部数据源的请求压力。由于今天时间紧张,所以不深入谈它的原理和用法了,之后会再提。看官如果想了解的话,可以先参考官方文档和FLIP-12给出的设计细节。

但是,异步I/O对于那种变化缓慢并且规模不大的维度数据,就显得有些杀鸡用牛刀了。我们完全可以自己做个轻量级的实现。下面举出一个示例,它从订单日志中取出站点ID、城市ID,然后从存储在MySQL的维度表中获取站点名和城市名,并写回订单日志。

public static final class MapWithSiteInfoFuncextends RichMapFunction {private static final Logger LOGGER &#61; LoggerFactory.getLogger(MapWithSiteInfoFunc.class);private static final long serialVersionUID &#61; 1L;private transient ScheduledExecutorService dbScheduler;private Map siteInfoCache;&#64;Overridepublic void open(Configuration parameters) throws Exception {super.open(parameters);siteInfoCache &#61; new HashMap<>(1024);dbScheduler &#61; new ScheduledThreadPoolExecutor(1, r -> {Thread thread &#61; new Thread(r, "site-info-update-thread");thread.setUncaughtExceptionHandler((t, e) -> {LOGGER.error("Thread " t " got uncaught exception: " e);});return thread;});dbScheduler.scheduleWithFixedDelay(() -> {try {QueryRunner queryRunner &#61; new QueryRunner(JdbcUtil.getDataSource());List> info &#61; queryRunner.query(SITE_INFO_QUERY_SQL, new MapListHandler());for (Map item : info) {siteInfoCache.put((int) item.get("site_id"), new SiteAndCityInfo((int) item.get("site_id"),(String) item.getOrDefault("site_name", ""),(long) item.get("city_id"),(String) item.getOrDefault("city_name", "")));}LOGGER.info("Fetched {} site info records, {} records in cache", info.size(), siteInfoCache.size());} catch (Exception e) {LOGGER.error("Exception occurred when querying: " e);}}, 0, 10 * 60, TimeUnit.SECONDS);}&#64;Overridepublic String map(String value) throws Exception {JSONObject json &#61; JSON.parseObject(value);int siteId &#61; json.getInteger("site_id");String siteName &#61; "", cityName &#61; "";SiteAndCityInfo info &#61; siteInfoCache.getOrDefault(siteId, null);if (info !&#61; null) {siteName &#61; info.getSiteName();cityName &#61; info.getCityName();}json.put("site_name", siteName);json.put("city_name", cityName);return json.toJSONString();}&#64;Overridepublic void close() throws Exception {siteInfoCache.clear();ExecutorUtils.gracefulShutdown(10, TimeUnit.SECONDS, dbScheduler);JdbcUtil.close();super.close();}private static final String SITE_INFO_QUERY_SQL &#61; "...";}

这段代码的思路很直接&#xff1a;用一个RichMapFunction封装整个join过程&#xff0c;用一个单线程的调度线程池每隔10分钟请求MySQL&#xff0c;拉取想要的维度表数据存入HashMap&#xff0c;再根据日志中的ID查HashMap就完事了。为了安全&#xff0c;在RichMapFunction的close()方法里要记得关闭线程池和连接。

上述代码中的QueryRunner和MapListHandler来自Apache Commons框架里的JDBC工具DBUtils。JdbcUtil中则封装了MySQL连接的参数与DBCP2里的基本连接池BasicDataSource&#xff0c;很简单&#xff0c;看官可以自行实现。



声明&#xff1a;本号所有文章除特殊注明&#xff0c;都为原创&#xff0c;公众号读者拥有优先阅读权&#xff0c;未经作者本人允许不得转载&#xff0c;否则追究侵权责任。

关注我的公众号&#xff0c;后台回复【JAVAPDF】获取200页面试题&#xff01;5万人关注的大数据成神之路&#xff0c;不来了解一下吗&#xff1f;5万人关注的大数据成神之路&#xff0c;真的不来了解一下吗&#xff1f;5万人关注的大数据成神之路&#xff0c;确定真的不来了解一下吗&#xff1f;

欢迎您关注《大数据成神之路》

大数据技术与架构


推荐阅读
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • mysql-cluster集群sql节点高可用keepalived的故障处理过程
    本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 本文记录了在vue cli 3.x中移除console的一些采坑经验,通过使用uglifyjs-webpack-plugin插件,在vue.config.js中进行相关配置,包括设置minimizer、UglifyJsPlugin和compress等参数,最终成功移除了console。同时,还包括了一些可能出现的报错情况和解决方法。 ... [详细]
  • Android系统源码分析Zygote和SystemServer启动过程详解
    本文详细解析了Android系统源码中Zygote和SystemServer的启动过程。首先介绍了系统framework层启动的内容,帮助理解四大组件的启动和管理过程。接着介绍了AMS、PMS等系统服务的作用和调用方式。然后详细分析了Zygote的启动过程,解释了Zygote在Android启动过程中的决定作用。最后通过时序图展示了整个过程。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
author-avatar
ayuanliang
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有