[译] Java 数据流的不同应用场景

8,202 阅读6分钟

数据流

数据流是一种数据分发技术,数据生产者将数据记录写入有序数据流,数据消费者可以从该数据流中以相同的顺序读取数据。这是一张用于说明数据生产者,数据流和数据消费者的简单数据流图:

数据生产者和消费者的数据流记录

数据流可以有很多变量

从“表面”上看,数据流是一种很简单的概念。数据生产者将记录存储到数据流中,随后消费者可以从中读取。不过,透过这层表面,我们可以看到还是存在一些细节操作会影响数据流系统的“外观”,这会进而影响它的行为以及你可以进行的动作。

每个数据流产品都会对用例和处理技术做一定的假设(用于技术支持)。这些假设会导致某些设计选择最后影响你可以用来实现数据流处理行为的类型。这个数据流教程将检查哪些设计选择,并基于这些设计选择讨论他们对用户产品造成的影响。

数据流可以解耦生产者和消费者

数据流将数据生产者和数据消费者相互解耦。当数据生产者将其数据简单写入数据流时,生产者不需要知道读取数据的消费者。消费者可以独立于生产者进行添加和删除。消费者可以在生产者不知情的情况下,启动/停止或暂停并恢复他们的消费。这种解耦简化了数据生产者和使用者的实现。

据流作为数据共享机制

数据流是在大型分布式系统中存储和共享数据的一种非常有用的机制。如前所述,数据生产者只需将数据发送至数据流系统。生产者不需要知道任何关于消费者的事情。消费者可以在不影响生产者的情况下,上线、下线、添加或者移除自己。

像 LinkedIn 这样的大公司在内部广泛使用数据流。Uber 也在内部使用数据流。许多企业级公司正在采用或已经采用内部数据流。许多初创公司也是如此。

持久化数据流

数据流是可以持久化的,在这种情况下,它被称为 logjournal。持久化数据流的优点是数据流中的数据可以在数据流服务关闭后“存活”下来,因此数据记录不会被丢失。

相比于在内存中保存记录的数据流服务相比,持久化数据流服务通常可以保存更多的历史数据。有些数据流保存的历史数据甚至可以追溯到写入数据流的第一条记录。有些只保存部分历史数据。

在持久化数据流保存完整历史记录的情况下,消费者可以重复处理所有记录,可以基于这些记录重建它们的内部状态。如果消费者在自己的代码中发现了 BUG,它就可以更正代码然后重现数据流来重建内部数据库。

数据流用例

数据流是一个非常通用的概念,它可以用于支持多种不同的用例。在本节中,我将介绍一些更常用的数据流用例。

用于事件驱动架构的数据流

数据流常用于事件驱动架构。事件由事件生产者作为记录写入某些数据流系统, 事件消费者可以从中读取这些事件。

用于智能城市和物联网的数据流

数据流也可以应用于传输在智能城市周围的传感器的数据,用于智能工厂内传感器或者来自其他物联网设备传感器的流数据。像温度,污染程度等这样的数值可以定期从设备中采样并写入数据流。数据消费者可以在需要时从数据流中读取样本。

用于常规数据抽样的数据流

智能城市中传感器和物联网设备只是数据源的两个例子,这些数据源可以定期采样并通过数据流提供。还有许多其他类型的数据可以定期采样并以流形式提供。例如,货币汇率或股票价格也可以抽样和流传输。民意数值也可以定期采样和流式传输。

用于数据点的数据流

在民调支持率的事例中,你可以决定每个独立答案将要流向的民意投票流中,而不用流向定期抽样的总数。由独立数据点(如投票)组成总数有时会比计算总数来得更有意义。这取决于具体的用例和其他因素,例如单个数据点是匿名的还是包含不应该共享的私有的个人信息。

记录、消息、事件和抽样等。

数据流记录有时被称为消息、事件、抽样和其他术语。使用哪个术语取决于数据流的具体用例,以及生产者和消费者对数据的处理和响应方式。通常情况,从用例中可以比较清楚地知道用例引用记录的具体意义。

值得注意的是,用例也会影响给定记录所代表的内容。并非所有的数据记录都是相同的。事件与抽象值不一样,不能总是以相同的方式使用。在本教程(和/或者其他教程)中,我将更详细地讨论这一点。

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏