Exploring Time Travel Queries in Apache Hudi

Apache Hudi (Hadoop Upserts Deletes and Incrementals) is an advanced data management framework designed to efficiently handle large-scale datasets. One of its standout features is time travel, which allows users to query historical versions of their data. This feature is essential for scenarios where you need to audit changes, recover from data issues, or simply analyze how data has evolved over time. In this blog post, we’ll walk through the process of setting up Hudi for time travel queries, using AWS Glue and PySpark for a hands-on example.

1. Getting Started: Importing Libraries and Creating Spark Context

First, ensure you have all the necessary libraries in place. In this example, we’ll be using PySpark along with Hudi on AWS Glue notebook to manage data and run our queries. Make sure to import the relevant libraries and establish a Spark and Glue context before proceeding

2. Setting Up Your Hudi Table

Before we can explore time travel queries, you need to set up a Hudi table where your data will reside. To do this, define your database and table names, and provide an S3 path where your data will be stored.

3. Creating and Populating the Hudi Table

After defining the table, you can now generate data and create a DataFrame in PySpark. Once your data is ready, write it to Hudi. This action creates the initial version of your dataset.

4. Working with Time Travel Queries

To demonstrate the power of time travel in Hudi, we’ll make updates to the data and observe how these changes are reflected at different points in time. For example, you can append new records to the table, which will trigger Hudi to create a new version of the data while retaining the previous versions in parquet files. We also updated the current record. After appending, you will notice that a new parquet file is created, while the previous records remain intact. Next, we will update an existing record:

5. Listing Commit Times for Time Travel and performing a Time Travel Query:

In Hudi, commit times (also called instant times) play a key role in versioning. Each time data is written or updated, Hudi stores a new commit time. To perform a time travel query, you first need to list these commit times and select the one you’d like to query. · meta_df = spark.read.format(“hudi”).load(final_base_path) This line reads the Hudi table from the S3 path (final_base_path) into a Spark DataFrame. Hudi maintains metadata along with the data itself, including commit times (known as instant times) stored in the _hoodie_commit_time field. The Hudi table can store multiple versions of the data through these commit times. · meta_df.createOrReplaceTempView(“hudi_metadata”) Here, a temporary SQL view called “hudi_metadata” is created from the DataFrame meta_df. This allows us to run SQL queries directly on the metadata of the Hudi table. · commit_time_df = spark.sql(“SELECT distinct(_hoodie_commit_time) as commit_time FROM hudi_metadata order by commit_time desc”) This SQL query fetches all distinct commit times (_hoodie_commit_time) from the Hudi table’s metadata. To perform a time travel query, use the commit time you retrieved earlier. By specifying the commit time using the as.of.instant option, Hudi allows you to view the state of the data as it existed at that specific point in time.

6. Why Time Travel is Important

Apache Hudi’s time travel capability is a game-changer for data management. It provides:

  • · Data Auditing: You can review the state of the data at any past commit.
  • · Data Rollback: If an issue arises in a recent commit, you can easily revert to a previous version of the data.
  • . Historical Analysis: Analyze how your data has evolved without storing multiple copies manually.

Conclusion

Time travel in Apache Hudi is a powerful feature for querying historical data versions. It enables efficient data auditing, rollback, and analysis, which are crucial for any modern data pipeline. By following the steps in this blog, you can quickly set up Hudi and leverage this feature in your workflows. Whether you’re working in AWS Glue or a similar environment, Hudi’s time travel queries simplify managing complex datasets.

Blog Pundits: Sandeep Rawat
 
Opstree is an End to End DevOps solution provider
 

Connect With Us

 

Connect With Us

🚀 Webinar: Maximize ROI with DevSecOps

Uncover strategies to accelerate releases, enhance security, and reduce costs with an internal DevSecOps platform. Master CI/CD, automation, and ROI measurement in this value-packed session tailored for tech leaders and DevOps pros!

📅 Date & Time:

ET: 11:00 AM – 01:00 PM IST: 8:30 PM – 10:30 PM

Author: Ramneek Kaur

I am a Data Engineer at OpsTree Global, currently contributing to major data initiatives for enterprise customers.I have deep expertise in designing and implementing scalable ETL pipelines, building robust cloud-native data platforms, and enabling real-time analytics using tools like BigQuery, GCP, Airflow, Kafka, and Mesh.My work focuses heavily on query performance tuning, pipeline reliability, and cost optimization, ensuring that data systems remain both efficient and resilient under scale. I hold a B.Tech degree in Computer Science and am passionate about building future-safe, maintainable data ecosystems that empower data-driven decision-making in organizations.

Leave a Reply