ストリーム処理

Announcing ksqlDB 0.8.0

The latest ksqlDB release introduces long-awaited features such as tunable retention and grace period for windowed aggregates, new built-in functions including LATEST_BY_OFFSET, a peek at the new server API under development, and more.

Tunable retention and grace period for windowed aggregates

ksqlDB supports window-based aggregation of events. You can use the following query, for instance, to count the number of pageviews per region in each minute-long interval:

CREATE TABLE pageviews_per_region AS
    SELECT regionid, COUNT(*) from pageviews
    WINDOW TUMBLING (SIZE 1 MINUTE)
    GROUP BY regionid
    EMIT CHANGES;

However, the aggregation results for each (minute-long) window can’t be stored forever as storage space is finite. The amount of time ksqlDB stores windowed results for is the retention time.

With ksqlDB 0.8.0, this retention time is configurable in the aggregation statement itself by specifying a retention clause, such as RETENTION 7 DAYS.

CREATE TABLE pageviews_per_region AS
    SELECT regionid, COUNT(*) from pageviews
    WINDOW TUMBLING (SIZE 1 MINUTE, RETENTION 7 DAYS)
    GROUP BY regionid
    EMIT CHANGES;

This is very helpful for applications that rely on ksqlDB’s query serving layer. For example, it’s now possible to materialize windowed metrics inside ksqlDB and store the data for weeks or months to directly support a dashboard served by ksqlDB.

When working with windowed aggregates, another parameter of interest is the grace period—the length of time each window continues to accept and process late-arriving events after the end of the window. This is important because event streaming applications often have to deal with events arriving later than the end of their expected window.

With ksqlDB 0.8.0, the grace period for late-arriving events included in windowed computations can be configured by specifying a clause such as GRACE PERIOD 10 MINUTES in the window expression:

CREATE TABLE pageviews_per_region AS
    SELECT regionid, COUNT(*) from pageviews
    WINDOW TUMBLING (SIZE 1 MINUTE, RETENTION 7 DAYS, GRACE PERIOD 10 MINUTES)
    GROUP BY regionid
    EMIT CHANGES;

For more details, see the documentation.

New aggregation function: LATEST_BY_OFFSET

With the release of ksqlDB 0.8.0, we’re happy to introduce one of the most highly requested built-in functions: LATEST_BY_OFFSET. The LATEST_BY_OFFSET aggregation function is used to track the latest value of a column when aggregating events from a stream into a table. As the function name suggests, latest is determined by offset order rather than timestamp order.

For example, consider a stream of IoT data:

CREATE STREAM sensor_readings (sensorID BIGINT, temp DOUBLE, quality INT)
    WITH (KAFKA_TOPIC='readings', VALUE_FORMAT='JSON', KEY='sensorID');

…with these example records:

{"sensorId": 1224, "temp": 56.4, "quality": 3},
{"sensorId": 2658, "temp": 56.4, "quality": 3},
{"sensorId": 1224, "temp": 96.4, "quality": 1},
...

A user interested in capturing the latest temperature and quality value for each sensor can do so with the following query:

CREATE TABLE aggregate_sensor_readings AS
    SELECT sensorId, LATEST_BY_OFFSET(temp), LATEST_BY_OFFSET(quality)
    FROM sensor_readings
    GROUP BY sensorId
    EMIT CHANGES;

And there’s more!

ksqlDB 0.8.0 also includes an early look at the new client and server API proposed in KLIP-15. This internal set of changes lays the groundwork for new features and enhancements to ksqlDB’s developer experience. We’re excited to share more of the KLIP-15 implementation in a future release and in other blog posts coming soon.

This release also made ksqlDB’s integration with Kafka Connect a little easier, as the ksqlDB server and CLI Docker images now ship with confluent-hub, an easy-to-use tool for installing connectors. With the inclusion of confluent-hub in ksqlDB, downloading connectors is as simple as a single command with a Docker image you already have. Check out the tutorial for running Kafka Connect embedded in ksqlDB for an example.

In addition, ksqlDB 0.8.0 introduces two more built-in functions, REGEXP_EXTRACT and ARRAY_LENGTH, as well as various bug fixes and other improvements. See the changelog for the complete list.

If you haven’t already, join us in our #ksqldb Confluent Community Slack channel and get started with ksqlDB today!

Victoria Xia joined the ksqlDB Team at Confluent in 2018 after completing her bachelor’s and master’s in electrical engineering and computer science at the Massachusetts Institute of Technology (MIT). Since then, she’s worked on a variety of projects spanning monitoring and alerting, performance benchmarking, security, and Confluent Cloud.

Did you like this blog post? Share it now

Subscribe to the Confluent blog

More Articles Like This

Real-Time Data Replication with ksqlDB

Real-Time Data Replication with ksqlDB

Data can originate in a number of different sources—transactional databases, mobile applications, external integrations, one-time scripts, etc.—but eventually it has to be synchronized to a central data warehouse for analysis […]

How to Make Your Open Source Apache Kafka Connector Available on Confluent Hub

How to Make Your Open Source Apache Kafka Connector Available on Confluent Hub

Do you have data you need to get into or out of Apache Kafka®? Kafka connectors are perfect for this. There are many connectors out there, usually for well-known and […]

ksqlDB: The Missing Link Between Real-Time Data and Big Data Streaming

ksqlDB: The Missing Link Between Real-Time Data and Big Data Streaming

Is event streaming or batch processing more efficient in data processing? Is an IoT system the same as a data analytics system, and a fast data system the same as […]

このウェブサイトでは、ユーザーエクスペリエンスの向上に加え、ウェブサイトのパフォーマンスとトラフィック分析のため、Cookie を使用しています。また、サイトの使用に関する情報をソーシャルメディア、広告、分析のパートナーと共有しています。

詳細情報