Configuring Database Retention
Goal
DataHub stores different versions of metadata aspects as they are ingested using a database (or key-value store). These multiple versions allow us to look at an aspect's historical changes and rollback to a previous version if incorrect metadata is ingested. However, every stored version takes additional storage space, while possibly bringing less value to the system. We need to be able to impose a retention policy on these records to keep the size of the DB in check.
Goal of the retention system is to be able to configure and enforce retention policies on documents at each of these various levels:
- global
- entity-level
- aspect-level
What type of retention policies are supported?
We support 3 types of retention policies for aspects:
| Policy | Versions Kept | 
|---|---|
| Indefinite | All versions | 
| Version-based | Latest N versions | 
| Time-based | Versions ingested in last N seconds | 
Note: The latest version (version 0) is never deleted. This ensures core functionality of DataHub is not impacted while applying retention.
When is the retention policy applied?
As of now, retention policies are applied in two places:
- GMS boot-up: A bootstrap step ingests the predefined set of retention policies. If no policy existed before or the existing policy was updated, an asynchronous call will be triggered. It will apply the retention policy (or policies) to all records in the database.
- Ingest: On every ingest, if an existing aspect got updated, it applies the retention policy to the urn-aspect pair being ingested.
We are planning to support a cron-based application of retention in the near future to ensure that the time-based retention is applied correctly.
How to configure?
For the initial iteration, we have made this feature opt-in. Please set ENTITY_SERVICE_ENABLE_RETENTION=true when creating the datahub-gms container/k8s pod.
On GMS start up, retention policies are initialized with:
- First, the default provided version-based retention to keep 20 latest aspects for all entity-aspect pairs.
- Second, we read YAML files from the /etc/datahub/plugins/retentiondirectory and overlay them on the default set of policies we provide.
For docker, we set docker-compose to mount ${HOME}/.datahub directory to /etc/datahub directory
within the containers, so you can customize the initial set of retention policies by creating
a ${HOME}/.datahub/plugins/retention/retention.yaml file.
We will support a standardized way to do this in Kubernetes setup in the near future.
The format for the YAML file is as follows:
- entity: "*" # denotes that policy will be applied to all entities
  aspect: "*" # denotes that policy will be applied to all aspects
  config:
    retention:
      version:
        maxVersions: 20
- entity: "dataset"
  aspect: "datasetProperties"
  config:
    retention:
      version:
        maxVersions: 20
      time:
        maxAgeInSeconds: 2592000 # 30 days
Note, it searches for the policies corresponding to the entity, aspect pair in the following order:
- entity, aspect
- *, aspect
- entity, *
- ,
By restarting datahub-gms after creating the plugin yaml file, the new set of retention policies will be applied.