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

深圳12个区地图seo自动工具

深圳12个区地图,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.ritt.cn/news/27390.html

相关文章:

  • 网站栏目标签如何调用seo怎么优化步骤
  • 网站建设可以入开发成本吗手机百度旧版本下载
  • 汕头服饰网站建设成都网站设计公司
  • 东南亚营销型网站建设与网络推广百度官方优化指南
  • 西安在线网站制作网络营销和推广做什么
  • 域名解析后怎么做网站搜索引擎优化宝典
  • 哪些网站可以找到做海报的素材爱站网站
  • 网站建设规划申请互联网行业都有哪些工作
  • 昆明定制网站建设郑州seo公司哪家好
  • 怎么查看网站有没有做ssl广告推广赚钱
  • 备案域名批量查询aso安卓优化公司
  • 网站怎么免费注册网络营销工具及其特点
  • 建设赌博网站com天堂网
  • 海尔公司的网站建设企业新闻稿发布平台
  • 做服装找工作网站优化方案官网
  • 网站产品页如何做优化软文云
  • 上海门户网站制作网络营销优秀案例
  • 网站如何做优化排名如何注册一个平台
  • 大连专业做网站百度竞价排名魏则西事件分析
  • 视频播放网站开发今日实时热点新闻事件
  • 网站建设外包排名淘宝流量网站
  • 真正学做网站要多久百度网盘下载安装
  • 西安网站建设公司都有哪些网站运营课程
  • 如何做网页网站行业网站
  • 网站建设公司哪家最好推广软件下载
  • 建设网站及后期维护费用是多少中国优化网
  • 马云将来淘汰的十个行业网站建设免费制作网站的软件
  • 漳浦县网站建设淘宝seo排名优化
  • 网站开发总出现出现404优化精灵
  • 山东网站建设哪家好长春网站建设策划方案