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

wordpress 子网站重命名建筑设计参考网站

wordpress 子网站重命名,建筑设计参考网站,广州建设网站的公司哪家好,做网站 你的出路在哪里对于许多状态流式计算程序来说#xff0c;一个常见的需求是自动清理应用程序的状态#xff08;state#xff09;#xff0c;以便有效地控制状态大小#xff0c;或者控制程序访问状态的有效时间#xff08;例如受限于诸如GDPR等法律条规#xff09;。Apache Flink自1.6.0…对于许多状态流式计算程序来说一个常见的需求是自动清理应用程序的状态state以便有效地控制状态大小或者控制程序访问状态的有效时间例如受限于诸如GDPR等法律条规。Apache Flink自1.6.0版本引入了状态的生存时间time-to-liveTTL功能使得应用程序的状态清理和有效的状态大小管理成为可能。 在本文中我们将讨论引入状态生存时间特性的动机并讨论其相关用例。此外我们还将演示如何使用和配置该特性。同时我们将会解释Flink如何借用状态生存时间特性在内部管理状态并对Flink 1.8.0中该功能引入的相关新特性进行一些展示。本文章最后对未来的改进和扩展作了展望。 状态的暂时性 有两个主要原因可以解释为什么状态只应该维持有限的时间。让我们先设想一个Flink应用程序它接收用户登录事件流并为每个用户存储上一次登录时的相关事件信息和时间戳以改善高频访问用户的体验。 控制状态的大小。 状态生存时间特性的主要使用场景就是能够有效地管理不断增长的状态大小。通常情况下数据只需要暂时保存例如用户处在一次网络连接会话中。当用户访问事件结束时我们实际上就没有必要保存该用户的状态来减少无谓的状态存储空间占用。Flink 1.8.0引入的基于生存时间的后台状态清理机制使得我们能够自动地对无用数据进行清理。此前应用程序开发人员必须采取额外的操作并显式地删除无用状态以释放存储空间。这种手动清理过程不仅容易出错而且效率低下。以我们上述用户登录的案例为例因为这些不活跃用户的相关信息会被自动过期清理掉我们就不再需要额外存储上次登录的时间戳。 符合(敏感)数据保护的要求。 随着数据隐私法规的发展例如欧盟颁布的通用数据保护法规GDPR遵守此类法规的相关要求或将数据进行敏感处理已经成为许多应用程序的首要任务。此类使用场景的的一个典型案例就需要仅在特定时间段内保存数据并防止其后可以再次访问该数据。这对于为客户提供短期服务的公司来说是一个常见的挑战。状态生存时间这一特性就保证了应用程序仅可以在有限时间内进行访问有助于遵守数据保护法规。 这两个需求都可以通过状态生存时间来解决这个功能可以周期性地、持续地删除状态中的键值一旦它变得不必要或不重要并且不再需要保存在存储中时。 对应用状态的持续清理 Apache Flink的1.6.0版本引入了状态生存时间特性。它使流处理应用程序的开发人员能够配置算子的状态使其在定义的超时生存时间后过期并被清除。在Flink 1.8.0中该功能得到了进一步扩展对RocksDB和堆内存状态后端FsStateBackend和MemoryStateBackend的旧数据进行连续性的清理。 在Flink的DataStream API中应用程序状态是由状态描述符state descriptor来定义的。状态生存时间是通过将StateTtlConfiguration对象传递给状态描述符来配置的。下面的Java示例演示了如何创建状态生存时间的配置并将其提供给状态描述符该状态描述符将用户的上次登录时间保存为Long值 import org.apache.flink.api.common.state.StateTtlConfig; import org.apache.flink.api.common.time.Time; import org.apache.flink.api.common.state.ValueStateDescriptor;StateTtlConfig ttlConfig StateTtlConfig.newBuilder(Time.days(7)).setUpdateType(StateTtlConfig.UpdateType.OnCreateAndWrite).setStateVisibility(StateTtlConfig.StateVisibility.NeverReturnExpired).build();ValueStateDescriptorLong lastUserLogin new ValueStateDescriptor(lastUserLogin, Long.class);lastUserLogin.enableTimeToLive(ttlConfig); Flink提供了多个选项来配置状态生存时间的行为: 什么时候重置生存时间 默认情况下当状态被修改时生存时间就会被更新。我们也可以在读操作访问状态时更新相关项的生存时间但这样要花费额外的写操作来更新时间戳。已经过期的数据是否可以访问 状态生存时间机制使用的是惰性策略来清除过期状态。这可能导致应用程序会尝试读取过期但尚未删除的状态。用户可以配置对这样的读取请求是否返回过期状态。无论哪种情况过期状态都会在之后立即被删除。虽然返回已经过期的状态有利于数据可用性但不返回过期状态更符合相关数据保护法规的要求。哪种时间语义被用于定义生存时间 在Apache Flink 1.8.0中用户只能根据处理时间Processing Time定义状态生存时间。未来的Flink版本中计划支持事件时间Event Time。 关于状态生存时间的更多信息可以参考Flink官方文档。 在实现上状态生存时间特性会额外存储上一次相关状态访问的时间戳。虽然这种方法增加了一些存储开销但它允许Flink在访问状态、创建检查点、恢复或存储清理过程时可以检查过期状态。 “取走垃圾数据” 在访问状态对象时Flink将检查其时间戳并在状态过期时清除状态是否返回过期状态则取决于配置的过期数据可见性。由于这种访问时才删除的特性除非被垃圾回收否则那些永远不被访问过期数据将仍然占用存储空间。 那么在没有显示处理过期状态的情况下如何删除这些数据呢通常我们可以配置不同的策略进行后台删除。 保证完整快照中不包含过期数据 Flink 1.6.0已经支持在创建检查点checkpoint或保存点savepoint的完整快照时不包含过期状态。需要注意的是创建增量快照时并不支持剔除过期状态。完整快照时的过期状态剔除必须如下例所示进行显示启用 StateTtlConfig ttlConfig StateTtlConfig.newBuilder(Time.days(7)).cleanupFullSnapshot().build(); 上述配置并不会影响本地状态存储的大小但是整个作业的完整快照的大小将会减小。只有当用户从快照重新加载其状态到本地时才会清除用户的本地状态。 由于上述这些限制在Flink 1.6.0中程序仍需要过期后主动删除状态。为了改善用户体验Flink1.8.0引入了两种自主清理策略分别针对两种状态后端类型 堆内存状态后端的增量清理 此方法只适用于堆内存状态后端FsStateBackend和MemoryStateBackend。其基本思路是在存储后端的所有状态条目上维护一个全局的惰性迭代器。某些事件例如状态访问会触发增量清理而每次触发增量清理时迭代器都会向前遍历删除已遍历的过期数据。以下代码示例展示了如何启用增量清理 StateTtlConfig ttlConfig StateTtlConfig.newBuilder(Time.days(7))// check 10 keys for every state access.cleanupIncrementally(10, false).build(); 如果启用该功能则每次状态访问都会触发清除。而每次清理时都会检查一定数量的状态条目是否过期。其中有两个调整参数。第一个定义了每次清理时要检查的状态条目数。第二个参数是一个标志位用于表示是否在每条记录处理record processed之后而不仅仅是访问状态state accessed都还额外触发清除逻辑。 关于这种方法有两个重要的注意事项首先是增量清理所花费的时间会增加记录处理的延迟。其次如果没有状态被访问state accessed或者没有记录被处理record processed过期的状态也将不会被删除。 RocksDB状态后端利用后台压缩来清理过期状态 如果使用RocksDB状态后端则可以启用另一种清理策略该策略基于Flink定制的RocksDB压缩过滤器compaction filter。RocksDB会定期运行异步的压缩流程以合并数据并减少相关存储的数据量该定制的压缩过滤器使用生存时间检查状态条目的过期时间戳并丢弃所有过期值。 使用此功能的第一步需要设置以下配置选项state.backend.rocksdb.ttl.compaction.filter.enabled。一旦配置使用RocksDB状态后端后如以下代码示例将会启用压缩清理策略 StateTtlConfig ttlConfig StateTtlConfig.newBuilder(Time.days(7)).cleanupInRocksdbCompactFilter().build(); 需要注意的是启用Flink的生存时间压缩过滤机制后会放缓RocksDB的压缩速度。 使用定时器进行状态清理 另一种手动清除状态的方法是基于Flink的计时器这也是社区评估的一个想法。使用这种方法将为每个状态访问注册一个清除计时器。这种方法的清理更加精准因为状态一旦过期就会被立刻删除。但是由于计时器会与原始状态一起存储会消耗空间开销也更大一些。 未来展望 除了上面提到的基于计时器的清理策略之外Flink社区还计划进一步改进状态生存时间特性。可能的改进包括为事件时间event time添加生存时间的支持目前只支持处理时间和为可查询状态queryable state启用状态生存时间机制。 总结 状态可访问时间的限制和应用程序状态大小的控制是状态流处理领域的常见挑战Flink的1.8.0版本通过添加对过期状态对象连续性后台清理的支持显著改进了状态生存时间特性。新的清理机制可以不再需要手动实现状态清理的工作而且由于惰性清理的机制执行效率也更高。总得来说状态生存时间方便用户控制应用程序状态的大小使得用户可以将精力集中在应用程序的核心逻辑开发上。 原文链接 本文为云栖社区原创内容未经允许不得转载。
http://www.huolong8.cn/news/112827/

相关文章:

  • 网站开发php价格做婚介打么网站好
  • 手机免费建网站wordpress开发找工作
  • 网站 优点wordpress 发布时间
  • 彩票交易网站开发wordpress论坛建设
  • 把货卖到国外有哪些平台关键词排名优化系统
  • 长沙营销型网站制作互联网公司排行
  • 软件开发网站开发中国有多少个网站
  • 品牌建设网站有哪些做网站的是不是程序员
  • 做视频怎样传到网站做网站卖大闸蟹
  • 企业网站开发开题报告上海关键词优化按天计费
  • 网页制作模板的网站云优化网站建设
  • 遵义网站建设哪家好淘宝客做网站推广赚钱吗
  • 外贸建站服务推广公司做商品网站
  • 网站建设课程 谷建门户网站含义
  • 各种wordpress图片相册插件比较找一个网站做优化分析
  • 江门网站自助建站成都程序员培训机构
  • 看案例网站备案 网站名称什么用
  • wordpress轻应用主机wordpress用哪个seo
  • seo网站怎么优化网站建设商业计划书
  • 用asp做的网站有哪些电子商务网站中最基本的系统是
  • 北京市住房建设投资建设网站国外网站众筹怎做
  • 行业协会网站建设wordpress在后台文章自定义表单
  • 网站制作公司咨询工作内容旅游景点网站设计论文
  • 上海网站建设最好的公司旅游网站哪家好又便宜
  • 商丘哪里有网站建设张家港个人网站制作
  • wordpress开发网站模板php做的网站怎么发布
  • 手机网站策划昆山网站推广
  • 网站设计 网站开发 优化网站维护工作内容有什么
  • 色一把做最好的网站温州网站优化价格
  • 筑龙网app下载兰州快速seo整站优化招商