当前位置: 首页 > news >正文

广告牌制作培训学校铁力seo

广告牌制作培训学校,铁力seo,招聘网站花钱做的简历有用没,专业网站设计背景 GenericWriteAheadSink原理是把接收记录按照检查点进行分段,每个到来的记录都放到对应的分段中,这些分段内的记录是作为算子状态的形式存储和故障恢复的,对于每个分段内的记录列表,flink会在收到检查点完成的通知时把他们都…

背景

GenericWriteAheadSink原理是把接收记录按照检查点进行分段,每个到来的记录都放到对应的分段中,这些分段内的记录是作为算子状态的形式存储和故障恢复的,对于每个分段内的记录列表,flink会在收到检查点完成的通知时把他们都写到外部存储中,本文对其中的检查点完成后是否对应的事务必须成功这个点进行讲解

源码解析GenericWriteAheadSink

首先开始进行checkpoint时代码如下

public void snapshotState(StateSnapshotContext context) throws Exception {super.snapshotState(context);// 把检查点id先放入本地变量中saveHandleInState(context.getCheckpointId(), context.getCheckpointTimestamp());this.checkpointedState.clear();for (PendingCheckpoint pendingCheckpoint : pendingCheckpoints) {// 把本地变量中的检查点存放到算子列表状态中this.checkpointedState.add(pendingCheckpoint);}}private void saveHandleInState(final long checkpointId, final long timestamp) throws Exception {PendingCheckpoint pendingCheckpoint =new PendingCheckpoint(checkpointId, subtaskIdx, timestamp, handle);// 把检查点id先放到   pendingCheckpoints本地变量中 pendingCheckpoints.add(pendingCheckpoint);}

其实接收检查点完成的通知:

public void notifyCheckpointComplete(long checkpointId) throws Exception {super.notifyCheckpointComplete(checkpointId);synchronized (pendingCheckpoints) {Iterator<PendingCheckpoint> pendingCheckpointIt = pendingCheckpoints.iterator();while (pendingCheckpointIt.hasNext()) {PendingCheckpoint pendingCheckpoint = pendingCheckpointIt.next();long pastCheckpointId = pendingCheckpoint.checkpointId;int subtaskId = pendingCheckpoint.subtaskId;long timestamp = pendingCheckpoint.timestamp;StreamStateHandle streamHandle = pendingCheckpoint.stateHandle;//把历史的+当前的还没有成功提交的检查点id对应的事务,重新调用sendValue方法并提交对应检查点的事务if (pastCheckpointId <= checkpointId) {try {// 历史的或者当前的事务未提交if (!committer.isCheckpointCommitted(subtaskId, pastCheckpointId)) {try (FSDataInputStream in = streamHandle.openInputStream()) {// 调用sendValue方法写数据boolean success =sendValues(new ReusingMutableToRegularIteratorWrapper<>(new InputViewIterator<>(new DataInputViewStreamWrapper(in),serializer),serializer),pastCheckpointId,timestamp);if (success) {//提交对应检查点对应的事务committer.commitCheckpoint(subtaskId, pastCheckpointId);streamHandle.discardState();pendingCheckpointIt.remove();}}} else {streamHandle.discardState();pendingCheckpointIt.remove();}} catch (Exception e) {// we have to break here to prevent a new (later) checkpoint// from being committed before this oneLOG.error("Could not commit checkpoint.", e);break;}}}}}

注意这里需要注意的是flink的检查点成功创建后才会使用notify方法进行通知,flink没有保证一定通知,此外通知之后不论这个notify方法中发生了什么异常都不影响flink已经创建了检查点的事实。
对应到我们这个例子,你就会发现在notify方法中有需要把历史检查点已经创建成功但是对应的事务没有提交的事务重新调用一次sendValue方法和提交对应检查点的事务,也就是说不是每一次检查点都能成功的提交事务,如果事务没有提交成功,等待下一次检查点的通知即可,下一个检查点的通知会把历史的检查点重新检测一次.

http://www.dinnco.com/news/72360.html

相关文章:

  • 安装网站到服务器内容营销策略有哪些
  • wordpress半次元主题seo网站制作优化
  • 台州椒江网站建设公司搜狗站长
  • 成都解放号网站建设品牌广告
  • 公安局 网站备案查询站长之家网站介绍
  • 成都短视频制作培训班优化合作平台
  • 做网站不挣钱精准信息300099
  • 网站卖东西怎么做的搜索引擎的网址有哪些
  • 网站后台无ftp销售新手怎么找客源
  • 代码网站模板怎么做关键词排名怎么查
  • 厦门做网站公司有哪些不花钱网站推广
  • 阿里巴巴网站的功能营销方案案例
  • 仿牌网站优化河南网站推广
  • 单页设计网站肇庆网站推广排名
  • .net网站与php网站网络舆情监控系统
  • 设计网站的一般过程网站优化公司大家好
  • 有多少网站可以推广业务深圳seo培训
  • 东莞免费自助建站模板百度流量统计
  • 重庆怎么做网站?今日头条官网首页
  • 在美国做垂直网站指数分布
  • 做网站单页视频南昌seo排名外包
  • 淘宝客做网站教程世界杯大数据
  • 开源建站软件常州谷歌优化
  • 祖传做网站搜索引擎优化管理实验报告
  • 建网站买空间阿里巴巴国际站关键词推广
  • 免费做网站页头图电子商务平台建设
  • 三级网站做爰广告联盟app下载官网
  • 重庆哪家做网站好百度宁波运营中心
  • 做兼职在线抠图网站百度贴吧官网首页
  • 网站建设 域名 空间网页平台做个业务推广