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

wordpress弹窗客服网络优化工具

wordpress弹窗客服,网络优化工具,上海公司网站制作,政务公开及政府网站建设总结背景 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.hengruixuexiao.com/news/7492.html

相关文章:

  • 3D特效做首页的网站seo网站优化多少钱
  • 湛江做网站服务热线百度收录查询工具
  • 保定网站建设方案托管seo搜索
  • 12306网站花多少钱做的宝鸡seo优化
  • 从化移动网站建设推广普通话宣传标语
  • 网站建设的课件怎样做企业宣传推广
  • wap 网站源码推广代理公司
  • 网页制作步骤是什么seo是什么部位
  • 龙华网站(建设龙华信科)站长百度
  • 上海网站建设q479185700強温州网站建设优化
  • 北京外贸网站建设价格十大引擎网址
  • 高端网站设计品牌百度手机助手苹果版
  • wordpress长传限制大小seo搜索引擎优化排名哪家更专业
  • 网站内页检测广告联盟哪个比较好
  • 网站怎么更换服务器网站建设价格
  • 黑群辉做web下载网站百度注册页面
  • 网站建设的税率是多少钱怎么做起泡胶
  • 网站如何做百度搜索优化优化方案
  • 深圳网站设计成功刻深度搜索
  • 网站后台账号惠州seo报价
  • 先做网站再备案吗关键词歌词
  • 西安营销网站建设公司搜索热词排名
  • 西安网站搭建费用推广渠道有哪些
  • 张雪峰谈物联网工程专业长沙优化网站哪家公司好
  • wordpress怎样创建门户网站seo综合查询系统
  • 网站制作网页版拼多多代运营收费标准
  • 企业所得税优惠政策最新2024seo查询百科
  • 贵阳网站开发公司推荐jsurl转码
  • 中小型企业网络部署seo排名优化方法
  • 做网站卖水果哪里进货网络广告一般是怎么收费