Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
"license": "Licensed under the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0)",
"$id": "https://polaris.apache.org/schemas/policies/system/data-compaction/2025-02-03.json",
"title": "Data Compaction Policy",
"description": "Inheritable Polaris policy schema for Iceberg table data compaction.",
"description": "Inheritable Polaris policy schema for Iceberg table data compaction",
"type": "object",
"properties": {
"version": {
"type": "string",
"const": "2025-02-03",
"description": "Schema version."
"description": "Schema version"
},
"enable": {
"type": "boolean",
Expand All @@ -32,7 +32,7 @@
"target_file_size_bytes": 134217728,
"compaction_strategy": "bin-pack",
"max-concurrent-file-group-rewrites": 5,
"my-key": "my-value"
"key1": "value1"
}
}
]
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
{
"license": "Licensed under the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0)",
"$id": "https://polaris.apache.org/schemas/policies/system/metadata-compaction/2025-02-03.json",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does the JSON magically land at the location specified in the ID somehow? Or do we always need a followup PR?

Also, it looks a little funny to use dates here given that the date in the PR may not align with the date the schema actually becomes effective. In the worst case, we could merge two versions in one day. Maybe just an incrementing number is easier?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately no. I hope I can publish it once for all based on the directory structure.

I want to keep them as the same for date as these are first batch, should be fine as nobody is using it. Once we release them at 1.0. We should follow the date schema strictly.

"title": "Metadata Compaction Policy",
"description": "Inheritable Polaris policy schema for Iceberg table metadata compaction",
"type": "object",
"properties": {
"version": {
"type": "string",
"const": "2025-02-03",
"description": "Schema version"
},
"enable": {
"type": "boolean",
"description": "Enable or disable metadata compaction."
},
"config": {
"type": "object",
"description": "A map containing custom configuration properties. Please note that interoperability is not guaranteed.",
"additionalProperties": {
"type": ["string", "number", "boolean"]
}
}
},
"required": ["enable"],
"additionalProperties": false,
"examples": [
{
"version": "2025-02-03",
"enable": true,
"config": {
"spec_id": 1,
"key1": "value1"
}
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
{
"license": "Licensed under the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0)",
"$id": "https://polaris.apache.org/schemas/policies/system/orphan-file-removal/2025-02-03.json",
"title": "Orphan File Removal Policy",
"description": "Inheritable Polaris policy schema for Iceberg table orphan file removal",
"type": "object",
"properties": {
"version": {
"type": "string",
"const": "2025-02-03",
"description": "Schema version"
},
"enable": {
"type": "boolean",
"description": "Enable or disable orphan file removal."
},
"max_orphan_file_age_in_days": {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@flyrain this also struggles me a bit, remove orphan policy can be even expressed in more than in just file age. We don't we opt for the config key similar to the other policies?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove orphan policy can be even expressed in more than in just file age.

Can you name them? We can put them into schema if they are commonly used, otherwise, the config map would be the best place to be.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd vote for the config map

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If no extra field is suggested, we could keep it as is.

"type": "number",
"description": "Specifies the maximum age (in days) for orphaned files before they are eligible for removal."
},
"locations": {
"type": "array",
"items": {
"type": "string"
},
"description": "Specifies a list of custom directories to search for files instead of the default table location. Use with caution—if set to a broad location (e.g., s3://my-bucket instead of s3://my-bucket/my-table-location), all unreferenced files in that path may be permanently deleted, including files from other tables. Following best practices, tables should be stored in separate locations to avoid accidental data loss."
},
"config": {
"type": "object",
"description": "A map containing custom configuration properties. Note that interoperability is not guaranteed.",
"additionalProperties": {
"type": ["string", "number", "boolean"]
}
}
},
"required": ["enable"],
"additionalProperties": false,
"examples": [
{
"version": "2025-02-03",
"enable": true,
"max_orphan_file_age_in_days": 30,
"location": "s3://my-bucket/my-table-location",
"config": {
"prefix_mismatch_mode": "ignore",
"key1": "value1"
}
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
{
"license": "Licensed under the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0)",
"$id": "https://polaris.apache.org/schemas/policies/system/snapshot-retention/2025-02-03.json",
"title": "Snapshot Retention Policy",
"description": "Inheritable Polaris policy schema for Iceberg table snapshot retention",
"type": "object",
"properties": {
"version": {
"type": "string",
"const": "2025-02-03",
"description": "Schema version"
},
"enable": {
"type": "boolean",
"description": "Enable or disable snapshot retention."
},
"config": {
"type": "object",
"description": "A map containing custom configuration properties. Please note that interoperability is not guaranteed.",
"additionalProperties": {
"type": ["string", "number", "boolean"]
}
}
},
"required": ["enable"],
"additionalProperties": false,
"examples": [
{
"version": "2025-02-03",
"enable": true,
"config": {
"min_snapshot_to_keep": 1,
"max_snapshot_age_days": 2,
"max_ref_age_days": 3,
"key1": "value1"
}
}
]
}