Seal^_^【送书活动第2期】——《Flink入门与实战》

Seal^_^【送书活动第2期】——《Flink入门与实战》

  • 一、参与方式
  • 二、本期推荐图书
    • 2.1 作者简介
    • 2.2 编辑推荐
    • 2.3 前 言
    • 2.4 本书特点
    • 2.5 内容简介
    • 2.6 本书适用读者
    • 2.7 书籍目录
  • 三、正版购买

一、参与方式

评论:"掌握Flink,驭大数据,实战无惧!",即可参与成功。

1、关注博主的账号。
2、点赞、收藏、评论博主的文章。
3、在文章下留下评论,每位参与者最多可以评论三次。

📚 本次抽奖将 送出1至3本 书籍,具体数量取决于活动期间的阅读量,阅读量越高,送出的书籍数量也会相应增加。

🕚 活动截止时间为 2024年4月30日晚上8点整。博主将会抽奖程序随机抽取幸运观众,并在动态中公布抽奖结果

如果您有特殊需求或想要获取更多福利,请添加博主的微信号(文末)、加入粉丝福利群

注意: 活动结束后,中奖观众将会收到博主的私信通知,请留意查看您的私信消息、关注博主动态查看中奖信息。

二、本期推荐图书

在这里插入图片描述

2.1 作者简介

汪明,中国矿业大学硕士,徐州软件协会副理事长,某创业公司合伙人。从事软件行业十余年,发表论文数十篇。著有图书《Python大数据处理库PySpark实战》《TypeScript实战》《Go并发编程实战》。

2.2 编辑推荐

1、由于阿里对Flink的收购以及改进,目前Flink社区非常活跃,社区一直致力于统一流处理和批处理API,并逐步增强Flink SQL相关功能,即期望通过SQL来满足大部分的大数据ETL处理场景。

2、Flink在百度、阿里、字节跳动、小米和腾讯等商业巨头中有成熟的应用,每日可以处理万亿的事件,且可以维护TB级别的状态信息。

3、如果你对实时大数据处理感兴趣,致力于构建分布式大数据处理应用程序,并且有一点Java编程基础,那么本书适合你。

4、本书先对Flink基本的安装过程进行说明,并对Flink分布式架构、内部数据处理过程等进行详细分析,最后结合一个综合案例讲解大数据实时处理过程。

5、本书以实例为主线,激发读者的阅读兴趣,让读者能够真正学习到Flink 最实用、最前沿的技术。

2.3 前 言

随着物联网、5G以及大数据技术的发展,人类已经进入大数据时代,毫不夸张地说,未来IT相关的职位,一项必备技能就是大数据处理能力。当前,人类基于大数据和人工智能等技术,在特定领域中可以大大提升业务系统的智能化水平。

人类对于计算速度的追求从未停止,即使面对海量的数据,我们也希望大数据框架可以在非常低的延迟下进行响应,从而提升用户的体验。

主流的分布式大数据计算框架有Storm、Spark和Flink,由于阿里对Flink的收购以及改进,目前Flink社区非常活跃,社区一直致力于统一流处理和批处理API,并逐步增强Flink SQL相关功能,即期望通过SQL来满足大部分的大数据ETL处理场景。另外,随着Flink SQL功能的增强和发展,也大大降低了Flink学习的难度。

目前,Flink在百度、阿里、字节跳动、小米和腾讯等商业巨头中有成熟的应用,每日可以处理万亿的事件,且可以维护TB级别的状态信息。Flink支持多种编程语言,可以用Java、Scala以及Python进行大数据业务处理。与此同时,Flink支持灵活的窗口计算以及乱序数据处理,这相对于其他大数据计算框架来说,有比较强的优势。

如果你对实时大数据处理感兴趣,致力于构建分布式大数据处理应用程序,并且有一点Java编程基础,那么本书适合你。本书作为Flink的入门教材,由浅入深地对Flink大数据处理方法进行介绍,特别对常用的DataStream API和DataSet API、Table API 和SQL进行了详细的说明,最后结合实战项目,将各个知识点有机整合,做到理论联系实际。

本书涉及的技术和框架:

本书涉及的技术和框架包括Flink、IntelliJ IDEA、Java、Kafka、jQuery、HTML5、Node.js、Maven。

2.4 本书特点

(1)理论联系实际。本书先对Flink基本的安装过程进行说明,并对Flink分布式架构、内部数据处理过程等进行详细分析,最后结合示例代码进行说明,做到理论联系实际。

(2)深入浅出、轻松易学。本书以实例为主线,激发读者的阅读兴趣,让读者能够真正学习到Flink 最实用、最前沿的技术。

(3)技术新颖、与时俱进。本书结合当前最热门的技术,如Node.js和HTML5等,让读者在学习Flink的同时,了解更多相关的先进技术。

(4)贴心提醒。本书根据需要在各章使用了很多“注意”小栏目,让读者可以在学习过程中更轻松地理解相关知识点及概念。

在这里插入图片描述

2.5 内容简介

Apache Flink是一个框架和分布式处理引擎,用于对无界和有界数据流进行有状态的计算,广泛应用于大数据相关的实际业务场景中。本书是一本从零开始讲解Flink的入门教材,学习本书需要有Java编程基础。

本书共分10章,内容包括Flink开发环境搭建、Flink架构和原理、时间和窗口、状态管理和容错机制、数据类型与序列化、DataStream API和DataSet API、Table API和SQL、Flink并行、Flink部署与应用,最后以一个Flink实战项目为例,对Flink相关知识进行综合实践,其中涉及Web页面展示、WebSocket协议和Node.js服务等技术。

本书内容详尽、示例丰富,适合作为Flink初学者必备的参考书,也非常适合作为高等院校和培训机构大数据及相关专业的师生教学参考。

2.6 本书适用读者

1、有一点Java编程基础的初学者

2、大数据处理与分析人员

3、 从事后端开发,对大数据开发有兴趣的人员

4、想用Flink构建大数据应用的人员

5、想从事大数据技术工作的大中专院校学生

6、Java开发和Java架构人员

7、大数据技术培训机构的师生

2.7 书籍目录

第1章 Flink环境搭建 1

1.1 下载安装 1

1.1.1 什么是Flink 1

1.1.2 Flink用户 3

1.1.3 JDK安装 4

1.1.4 Scala安装 7

1.1.5 Python安装 10

1.1.6 FinalShell安装 12

1.2 配置与开发工具 15

1.2.1 基础配置 15

1.2.2 IDEA开发工具 17

1.3 编译 19

1.3.1 Scala项目模板 19

1.3.2 Java项目模板 24

1.3.3 Python项目 28

1.3.4 项目编译 30

1.4 运行Flink应用 31

1.4.1 单机Standalone模式 31

1.4.2 多机Standalone模式 37

1.4.3 On Yarn集群模式 37

1.5 本章小结 38

第2章 定义、架构与原理 39

2.1 流处理的应用场景 39

2.1.1 数据预处理场景 40

2.1.2 预警场景 40

2.1.3 实时数量统计场景 40

2.1.4 数据库交互场景 40

2.1.5 跟踪场景 40

2.1.6 基于数据流的机器学习场景 41

2.1.7 实时自动控制场景 41

2.2 流处理的原理 41

2.2.1 流数据特征 41

2.2.2 Dataflow模型 42

2.2.3 数据流图 43

2.2.4 流处理操作 45

2.2.5 窗口操作 46

2.3 Flink架构分析 49

2.3.1 Flink常见概念 49

2.3.2 Flink主从架构 51

2.3.3 任务和算子链 52

2.4 Flink中的几个语义——Streams、State、Time、API 53

2.4.1 Streams流 53

2.4.2 State状态 54

2.4.3 Time时间 55

2.4.4 API接口 55

2.5 Flink组件 56

2.6 本章小结 57

第3章 时间和窗口 58

3.1 时间 58

3.1.1 Flink中的时间 58

3.1.2 时间的特性 60

3.2 Timestamp和Watermark 61

3.2.1 在SourceFunction中生成 61

3.2.2 在assignTimestampsAndWatermarks中生成 64

3.2.3 Watermarks传播机制 83

3.3 EventTime+Watermark解决乱序数据 95

3.3.1 无迟到的乱序数据 96

3.3.2 有迟到的乱序数据 104

3.4 WindowAssigner、Evictor以及Trigger 109

3.4.1 WindowAssigner 111

3.4.2 Trigger 116

3.4.3 Evictor 122

3.5 Window内部实现 126

3.5.1 Flink Window源码分析 126

3.5.2 Flink Window执行过程 130

3.6 Window使用 131

3.6.1 Time Window 131

3.6.2 Count Window 135

3.6.3 Session Window 138

3.6.4 自定义Window 140

3.7 Window聚合分类 144

3.7.1 增量聚合 144

3.7.2 全量聚合 146

3.8 本章小结 149

第4章 状态管理及容错机制 150

4.1 什么是状态 150

4.2 什么场景会用到状态 150

4.3 状态的类型与使用 151

4.3.1 Keyed State托管状态 152

4.3.2 Operator State托管状态 159

4.4 Checkpoint机制 162

4.4.1 Checkpoint配置 163

4.4.2 State Backends状态后端 164

4.4.3 重启策略 165

4.5 SavePoint机制 169

4.6 本章小结 169

第5章 数据类型与序列化 170

5.1 Flink的数据类型 170

5.1.1 元组类型 171

5.1.2 Java POJOs类型 172

5.1.3 Scala样例类 173

5.1.4 基础类型 174

5.1.5 普通类 175

5.1.6 值类型 177

5.1.7 特殊类型 177

5.2 序列化原理 178

5.3 Flink的序列化过程 181

5.4 序列化的最佳实践 186

5.5 本章小结 186

第6章 DataStream API和DataSet API 187

6.1 DataStream API 187

6.1.1 DataSources数据输入 187

6.1.2 DataSteam转换操作 195

6.1.3 DataSinks数据输出 214

6.2 DataSet API 222

6.2.1 DataSources数据输入 223

6.2.2 DataSet转换操作 227

6.2.3 DataSinks数据输出 235

6.3 迭代计算 238

6.3.1 全量迭代 239

6.3.2 增量迭代 240

6.4 广播变量与分布式缓存 244

6.4.1 广播变量 244

6.4.2 分布式缓存 246

6.5 语义注解 248

6.5.1 Forwarded Fileds注解 248

6.5.2 Non-Forwarded Fileds注解 249

6.5.3 Read Fields注解 250

6.6 本章小结 251

第7章 Table API和SQL 252

7.1 TableEnviroment 252

7.1.1 开发环境构建 253

7.1.2 TableEnvironment基本操作 254

7.1.3 外部连接器 257

7.1.4 时间概念 261

7.1.5 Temporal Tables时态表 263

7.2 WordCount 267

7.3 Table API的操作 268

7.3.1 获取Table 268

7.3.2 输出Table 272

7.3.3 查询Table 275

7.3.4 聚合操作 277

7.3.5 多表关联 278

7.3.6 集合操作 279

7.3.7 排序操作 281

7.4 DataStream、DataSet和Table之间的转换 282

7.4.1 DataStream to Table 283

7.4.2 DataSet to Table 284

7.4.3 Table to DataStream 285

7.4.4 Table to DataSet 287

7.5 window aggregate与non-window aggregate 288

7.6 Flink SQL使用 297

7.6.1 使用SQL CLI客户端 298

7.6.2 在流上运行SQL查询 299

7.6.3 Group Windows窗口操作 300

7.6.4 多表关联 306

7.6.5 集合操作 307

7.6.6 去重操作 308

7.6.7 Top-N操作 310

7.6.8 数据写入 311

7.7 自定义函数 313

7.7.1 Scalar Function 313

7.7.2 Table Function 315

7.7.3 Aggregation Function 317

7.8 本章小结 319

第8章 并行 320

8.1 Flink并行度 320

8.2 TaskManager和Slot 321

8.3 并行度的设置 322

8.3.1 执行环境层面 322

8.3.2 操作算子层面 323

8.3.3 客户端层面 324

8.3.4 系统层面 324

8.3.5 最大并行度 324

8.4 并行度案例分析 325

8.5 本章小结 329

第9章 Flink部署与应用 330

9.1 Flink集群部署 330

9.1.1 Standalone Cluster部署 330

9.1.2 Yarn Cluster部署 333

9.1.3 Kubernetes Cluster部署 334

9.2 Flink高可用配置 340

9.2.1 Standalone集群高可用配置 340

9.2.2 Yarn Session集群高可用配置 341

9.3 Flink安全管理 341

9.3.1 认证目标 341

9.3.2 认证配置 342

9.3.3 SSL配置 343

9.4 Flink集群升级 344

9.4.1 任务重启 344

9.4.2 状态维护 344

9.4.3 版本升级 344

9.5 本章小结 345

第10章 Flink项目实战 346

10.1 实时数据清洗(实时ETL) 346

10.1.1 需求分析 346

10.1.2 项目架构设计 346

10.1.3 项目代码实现 347

10.2 实时数据报表 357

10.2.1 需求分析 357

10.2.2 项目架构设计 357

10.2.3 项目代码实现 357

10.3 本章小结 362

三、正版购买

在这里插入图片描述

有兴趣的朋友可以前往查看。 tmall搜索关键词:

✨ Flink入门与实战,Flink ✨

🛒 链接直达:https://detail.tmall.com/item.htm?spm=a1z10.1-b.w9858442-8055933095.4.fH3HiL&id=651841634753

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/2601.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu下部署gerrit+报错分析(超详细)

Ubuntu下部署gerrit代码平台 之前安装过几次 最后都在Apache代理这里失败了,如下图,总是gerrit.config与Apache2.config配置有问题,后面换了使用ngnix代理,简单多了 安装Mysql、gerrit、jdk、git 这一步也是非必须得&#xff0…

【c++】list类接口函数介绍与深度剖析模拟实现

🔥个人主页:Quitecoder 🔥专栏:c笔记仓 朋友们大家好,本篇文章来到list有关部分,这一部分函数与前面的类似,我们简单讲解,重难点在模拟实现时的迭代器有关实现 目录 1.List介绍2.接…

转向敏捷财务规划,实现更快更自信的决策

随着数字化的到来,原本基于电子表格的时代正逐渐拉下帷幕,大部分企业开始摆脱依赖于电子表格进行计划、预算和预测的传统规划系统,寻求更符合当今市场要求的敏捷财务规划。但不得不承认,当下电子表格仍然是多数企业使用最广泛的工…

Wireshark数据包分析入门

Wireshark数据包分析 1. 网络协议基础1.1. 应传网数物(应表会传网数物) 2. 三次握手2.1. 第一次握手2.2. 第二次握手2.3. 第三次握手2.4. 三次握手后流量特征 3. 第一层---物理层(以太网)4. 第二层---数据链路层(PPP L…

ele pls 表格行内样式超出隐藏

使用 模板实现方案: 实现效果: 相关样式:

【网络技术】【Kali Linux】Wireshark嗅探(十)IPv4和IPv6

往期 Kali Linux 上的 Wireshark 嗅探实验见博客: 【网络技术】【Kali Linux】Wireshark嗅探(一)ping 和 ICMP 【网络技术】【Kali Linux】Wireshark嗅探(二)TCP 协议 【网络技术】【Kali Linux】Wireshark嗅探&…

Jenkins CI/CD 持续集成专题四 Jenkins服务器IP更换

一、查看brew 的 services brew services list 二、编辑 homebrew.mxcl.jenkins-lts.plist 将下面的httpListenAddress值修改为自己的ip 服务器,这里我是用的本机的ip 三 、重新启动 jenkins-lts brew services restart jenkins-lts 四 浏览器访问 http://10.85…

redis7安装与配置

一、下载 通过 redis官网 或者 redis中文网 下载。 以下是 redis 相关文档资料链接: redis源码地址 redis在线测试 redis命令参考 redis中文文档 历史发布版本的源码地址 二、版本命名规则 Redis从发布到现在,已经有十余年的时光了,…

云原生Service Mesh服务网格简单介绍

serviceMesh是什么 Service Mesh是一个用于处理服务间通信的基础设施层,旨在实现云原生应用复杂服务拓扑中的可靠请求传递。其基本构成是一组与应用一起部署的轻量级网络代理,这些代理对应用来说是透明的。Service Mesh通过统一的方式来控制和处理服务间…

双筒水封式防爆器使用方法要记好

双筒水封式防爆器使用方法要记好 型号(YC-STFB型) 双筒水封式防爆器属于双罐结构的水封式防爆器,安装在抽放瓦斯泵吸气侧和排气端的 管路上靠防爆器底部的水封保护井上井下、抽放泵站设备及用户按全;当瓦斯抽放时气体经由 进气…

【深度学习实战(24)】如何实现“断点续训”?

一、什么是断点续训: 中断的地方,继续训练。与加载预训练权重有什么区别呢?区别在于优化器参数和学习率变了。 二、如何实现“断点续训” 我们需要使用checkpoint方法保存,模型权重,优化器权重,训练轮数…

韩国机器人公司Rainbow Robotics推出RB-Y1轮式双臂机器人

文 | BFT机器人 近日,韩国机器人领域的佼佼者Rainbow Robotics揭开了RB-Y1移动机器人的神秘面纱,这款机器人以其创新的设计和卓越的功能引起了业界的广泛关注。与此同时,Rainbow Robotics还携手舍弗勒集团(提供汽车、工业技术服务…

SpringCloud整合Ribbon负载均衡器

目录 一、模块一:提供数据 1.1 首先将第一个实例打包 1.2 使用命令行设置不同权重 1.3 打开图形化界面看看权重是否配置成功。 二、模块二:调用模块一 三、修改默认负载均衡策略 四、自定义规则 ​编辑 五、完整代码 5.1 目录结构 5.2 配置文件 …

网络中其他协议

目录 DNS协议 域名简介 ICMP协议 ICMP功能 ICMP协议格式 ping命令 NAT技术 NATP NAT技术的限制 代理服务器 DNS协议 DNS(Domain Name System,域名系统)协议,是一个用来将域名转化为IP地址的应用层协议。 为什么有这个协…

“数据中心的秘密武器:ADOP AOC和DAC线缆的选择与优势”

🌵【DAC电缆和AOC电缆因其低延迟、低功耗和低成本而广泛应用于数据中心的高性能计算网络布线系统。DAC 电缆和 AOC 电缆有多种配置,以满足网络要求。每款产品均提供 10G SFP、25G SFP28、40G QSFP 和 100G QSFP28 数据速率,并提供从 40G 到 4…

python基础--流程控制之条件语句

目标 条件语句作用if语法if…else…多重判断if嵌套 一. 了解条件语句 假设一个场景: 同学们这个年龄去过网吧吗?去网吧进门想要上网必须做的一件事是做什么?(考虑重点)为什么要把身份证给工作人员?是不…

如何培养单元测试的习惯?怎样才算一个好的单元测试?

你是怎么编写单元测试的呢?很多人的做法是先把所有的功能代码都写完,然后,再针对写好的代码一点一点地补写测试。 在这种编写测试的做法中,单元测试扮演着非常不受人待见的角色。你的整个功能代码都写完了,再去写测试就…

RAG开山之作:结合参数化与非参数化记忆的知识密集型NLP任务新解法

20年RAG刚提出时的论文:Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks,也算是RAG的开山之作之一了。 摘要:检索增强生成(RAG)方法结合了预训练语言模型与基于检索的非参数化记忆,通过…

Vue+Echarts 实现中国地图和飞线效果

目录 实现效果准备 实现效果 在线预览:https://mouday.github.io/vue-demo/packages/china-map/dist/index.html 准备 高版本的echarts,不包含地图数据,需要自己下载到项目中 1、地图数据下载 https://datav.aliyun.com/portal/school/at…

Pasta:HHE Optimized Stream Cipher

参考文献: [Dae95] Daemen J .Cipher and hash function design strategies based on linear and differential cryptanalysis[J].Doctoral Dissertation K.u.leuven, 1995.[GPP11] Guo J, Peyrin T, Poschmann A. The PHOTON family of lightweight hash function…