3 weeks ago
Hi all,
I am new to Databricks and delta table. Recently I am researching on data archiving as we have data retention policy within the company.
I have studied the documentation (Archival support in Databricks | Databricks on AWS) and I am exploring the feasibility of applying such feature to my case.
Let say I have a requirement to archive the data after 5 years and all of the table are delta tables, I would like to ask the following questions:
1. How should I configure in Databricks?
2. Can I specify a datetime column in the table as archive reference duration? Or it simply count the duration from the time the record being inserted to the table?
3. Is there any difference in terms of archiving between managed table and external table?
3. Is there any difference in implementation if the environment is UC enabled?
4. As per my understanding, if we enable archive support but do not configure any lifecycle management on storage side (we are using Azure storage account), there is no cost saving on storage side as Databricks simply ignore the data and the underlining storage remains unchanged. May I know how we can configure lifecycle management on Azure storage account so it can algin with the archival support setting on Databricks side?
Highly appreciate if someone can help me with the above questions. Thanks in advance.
3 weeks ago - last edited 3 weeks ago
Hi @Brianben ,
Source: https://docs.databricks.com/en/optimizations/archive-delta.html
To enable archival support in Databricks, you need to set the archival interval through a table property. For example:
ALTER TABLE <table_name> SET TBLPROPERTIES (delta.timeUntilArchived = '1825 days');
In this case, delta.timeUntilArchived = '1825 days'
indicates the data should be archived after five years (assuming 365 days per year). Please note that Databricks archival support depends on corresponding cloud-side lifecycle management policies (such as those provided by Azure, AWS, or GCP).
Archiving in Databricks currently relies on the file creation time recorded in the Delta transaction log. There isnโt a built-in mechanism to use a custom datetime column as the trigger for archiving. In other words, Databricks will consider the age of data based on when it was written to the Delta log, not a separate timestamp column.
Based on current documentation, there are no differences in how archival works for managed vs. external Delta tables. The archival process is driven by the same Delta transaction log mechanism and cloud lifecycle management policies, regardless of whether your table is managed or external.
The existing documentation does not indicate a difference in enabling or configuring archival support for UC-enabled environments. Archival support relies on the Delta transaction log and compatible compute environments, which should operate similarly in both UC and non-UC settings.
If you only enable Databricks archival support without configuring lifecycle management on Azure, the data is merely marked as archived within Databricks but remains in the same storage tier on Azure, resulting in no cost reduction.
To align Databricks archival with cost-saving measures:
delta.timeUntilArchived
.For detailed guidance on creating and managing lifecycle policies in Azure Storage, please refer to:
https://learn.microsoft.com/en-us/azure/storage/blobs/lifecycle-management-overview
Please let us know if this raises further questions, or does answer everything.
3 weeks ago - last edited 3 weeks ago
Hi @Brianben ,
Source: https://docs.databricks.com/en/optimizations/archive-delta.html
To enable archival support in Databricks, you need to set the archival interval through a table property. For example:
ALTER TABLE <table_name> SET TBLPROPERTIES (delta.timeUntilArchived = '1825 days');
In this case, delta.timeUntilArchived = '1825 days'
indicates the data should be archived after five years (assuming 365 days per year). Please note that Databricks archival support depends on corresponding cloud-side lifecycle management policies (such as those provided by Azure, AWS, or GCP).
Archiving in Databricks currently relies on the file creation time recorded in the Delta transaction log. There isnโt a built-in mechanism to use a custom datetime column as the trigger for archiving. In other words, Databricks will consider the age of data based on when it was written to the Delta log, not a separate timestamp column.
Based on current documentation, there are no differences in how archival works for managed vs. external Delta tables. The archival process is driven by the same Delta transaction log mechanism and cloud lifecycle management policies, regardless of whether your table is managed or external.
The existing documentation does not indicate a difference in enabling or configuring archival support for UC-enabled environments. Archival support relies on the Delta transaction log and compatible compute environments, which should operate similarly in both UC and non-UC settings.
If you only enable Databricks archival support without configuring lifecycle management on Azure, the data is merely marked as archived within Databricks but remains in the same storage tier on Azure, resulting in no cost reduction.
To align Databricks archival with cost-saving measures:
delta.timeUntilArchived
.For detailed guidance on creating and managing lifecycle policies in Azure Storage, please refer to:
https://learn.microsoft.com/en-us/azure/storage/blobs/lifecycle-management-overview
Please let us know if this raises further questions, or does answer everything.
2 weeks ago
@VZLA Thank you very much for the detailed explanation. No further questions, thanks again.
2 weeks ago
@VZLA Just one further question, do you know is it possible for a parquet file under a delta table consist of two different data written date in behind? As I am worried that if I configure Azure lifecycle policy to move the data file after 5 years but it actually consist of some data that not yet past 5 years criteria, some data would be move away earlier than expect. Thanks.
2 weeks ago
Yes, it is possible for a Parquet file under a Delta table to consist of data written on different dates. This can happen because Delta Lake operations, such as inserts, updates, or deletes, create new Parquet files for the new records; along the same lines OPTIMIZE can compact multiple files into a single new file, which may contain data from different write operations. Therefore if a Parquet file contains data that is less than 5 years old, moving the file based on the file's creation date could indeed result in moving data that does not yet meet the 5-year criteria, so you would be moving data earlier than expected.
You can consider the following options, I've tried to sort them by complexity of implementation to keep things simpler:
2 weeks ago
@VZLA I just come up with a different thought. If every time we do a operation on existing data like update, delete or optimize, new parquet files will be created and the file creation date would be the latest time. Even we may have different write operation, we should always have a later creation time, right? That doesn't mean we postpone the data archiving rather than do it sooner than expect?
Sorry for so many questions. Thanks in advance.
2 weeks ago
@Brianben Correct, apologies if my previous response is introducing further confusion. I had to go back to Azure's documentation to get more in context, initially I was considering timestamps inside the files, instead of the files metadata timestamp.
Anyways, you're absolutely correct. To clarify:
The delayed archival will happen when operations like updates, deletes, or compactions modify a file, resetting its "last modified" or "creation date." Example: A file originally written on Jan 1, 2018 and updated on Jan 1, 2023 will now have a "last modified date" of Jan 1, 2023, delaying archival until Jan 1, 2028 (5 years later). Data from 2018 will effectively be archived 10 years after its original creation. And then with respect to the premature archival clarification, because the Lifecycle policies only act on blob metadata (e.g., creation or modification dates), not the timestamps of individual rows inside the Parquet files, the risk of premature archival for "newer" data inside a file does not exist when using standard lifecycle policies.
2 weeks ago
@VZLA Got it, thank you for the detail explanation.
Join a Regional User Group to connect with local Databricks users. Events will be happening in your city, and you wonโt want to miss the chance to attend and share knowledge.
If there isnโt a group near you, start one and help create a community that brings people together.
Request a New Group