-
Notifications
You must be signed in to change notification settings - Fork 156
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support persisting TableMetadata in the metastore #433
Open
eric-maynard
wants to merge
59
commits into
apache:main
Choose a base branch
from
eric-maynard:metadata-cache
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 43 commits
Commits
Show all changes
59 commits
Select commit
Hold shift + click to select a range
6c90a3d
wip
eric-maynard bda008e
first real commit
eric-maynard c38a01d
cleaning up
eric-maynard 3a69953
tests fixed
eric-maynard ca856ed
begin refactoring
eric-maynard 779d912
wire up to loadTable
eric-maynard b4c5335
autolint
eric-maynard 6e23be4
logic to purge old records
eric-maynard 5805679
autolint
eric-maynard f32a82c
stable, disabled
eric-maynard 249ecac
passing when enabled
eric-maynard 0db85eb
stable
eric-maynard 6f0d9df
autolint
eric-maynard c0ea191
resolve conflicts; pull main
eric-maynard f250916
autolint
eric-maynard dd87d42
oops
eric-maynard c46eb03
add try/catch
eric-maynard 1e1b953
autolint
eric-maynard a164807
added drop-on-drop
eric-maynard 6ed3f97
autolint
eric-maynard 35b852f
refactor to remove new entity
eric-maynard 0b3df37
autolint
eric-maynard 5f7c74f
fixes
eric-maynard d99a796
autolint
eric-maynard f1023ec
stable
eric-maynard 045d93d
autolint
eric-maynard 20edca5
polish
eric-maynard f189e98
one fix
eric-maynard 5e90ba2
autolint
eric-maynard fbdce6a
?
eric-maynard f1461e5
more widespread use of loadTableMetadata
eric-maynard c5081d5
autolint
eric-maynard 452c5a1
persist on write
eric-maynard b85ad92
autolint
eric-maynard fde3910
debugging
eric-maynard 34b9b0f
fix failing test, add TODO
eric-maynard 6bc07c8
debugging
eric-maynard a9dcaa1
fix current metadata check
eric-maynard 9b66016
autolint
eric-maynard 52b82f7
fix
eric-maynard ee3f401
one change per review
eric-maynard 69c2ca5
fixes per review
eric-maynard 7b3e68d
autolint
eric-maynard 0b5291e
add a comment per review; make check more clear
eric-maynard 5488d76
autolint
eric-maynard 64e8d2b
fix method name
eric-maynard 5eca203
autolint
eric-maynard 7f89a24
remove check
eric-maynard 9829486
autolint
eric-maynard 73f5dd2
defer serialization
eric-maynard 59361ed
bounded serde
eric-maynard c67492f
autolint
eric-maynard 85ec25b
no more exceptions
eric-maynard 424b7d9
comment
eric-maynard 94b5864
Merge branch 'main' of github.com:apache/polaris into metadata-cache
eric-maynard a5fe3c1
fix
eric-maynard 0b152f7
autolint
eric-maynard 3584842
stable
eric-maynard 8d704eb
fix
eric-maynard File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -20,6 +20,7 @@ | |
|
||
import java.util.List; | ||
import java.util.Optional; | ||
import java.util.function.Function; | ||
import org.apache.polaris.core.admin.model.StorageConfigInfo; | ||
|
||
public class PolarisConfiguration<T> { | ||
|
@@ -29,15 +30,23 @@ public class PolarisConfiguration<T> { | |
public final T defaultValue; | ||
private final Optional<String> catalogConfigImpl; | ||
private final Class<T> typ; | ||
private final Optional<Function<T, Boolean>> validation; | ||
|
||
@SuppressWarnings("unchecked") | ||
public PolarisConfiguration( | ||
String key, String description, T defaultValue, Optional<String> catalogConfig) { | ||
String key, | ||
String description, | ||
T defaultValue, | ||
Optional<String> catalogConfig, | ||
Optional<Function<T, Boolean>> validation) { | ||
this.key = key; | ||
this.description = description; | ||
this.defaultValue = defaultValue; | ||
this.catalogConfigImpl = catalogConfig; | ||
this.typ = (Class<T>) defaultValue.getClass(); | ||
this.validation = validation; | ||
|
||
validate(cast(defaultValue)); | ||
} | ||
|
||
public boolean hasCatalogConfig() { | ||
|
@@ -52,14 +61,27 @@ public String catalogConfig() { | |
} | ||
|
||
T cast(Object value) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I kinda want to call this apply() now instead of cast ... :) Just because it does dual duty now |
||
return this.typ.cast(value); | ||
T result = this.typ.cast(value); | ||
validate(result); | ||
return result; | ||
} | ||
|
||
private void validate(T value) { | ||
this.validation.ifPresent( | ||
v -> { | ||
if (!v.apply(value)) { | ||
throw new IllegalArgumentException( | ||
String.format("Configuration %s has invalid value %s", key, defaultValue)); | ||
} | ||
}); | ||
} | ||
|
||
public static class Builder<T> { | ||
private String key; | ||
private String description; | ||
private T defaultValue; | ||
private Optional<String> catalogConfig = Optional.empty(); | ||
private Optional<Function<T, Boolean>> validation = Optional.empty(); | ||
|
||
public Builder<T> key(String key) { | ||
this.key = key; | ||
|
@@ -81,11 +103,16 @@ public Builder<T> catalogConfig(String catalogConfig) { | |
return this; | ||
} | ||
|
||
public Builder<T> validation(Function<T, Boolean> validation) { | ||
this.validation = Optional.of(validation); | ||
return this; | ||
} | ||
|
||
public PolarisConfiguration<T> build() { | ||
if (key == null || description == null || defaultValue == null) { | ||
throw new IllegalArgumentException("key, description, and defaultValue are required"); | ||
} | ||
return new PolarisConfiguration<>(key, description, defaultValue, catalogConfig); | ||
return new PolarisConfiguration<>(key, description, defaultValue, catalogConfig, validation); | ||
} | ||
} | ||
|
||
|
@@ -199,4 +226,15 @@ public static <T> Builder<T> builder() { | |
"If set to true, allows tables to be dropped with the purge parameter set to true.") | ||
.defaultValue(true) | ||
.build(); | ||
|
||
public static final Long METADATA_CACHE_MAX_BYTES_NO_CACHING = 0L; | ||
public static final PolarisConfiguration<Long> METADATA_CACHE_MAX_BYTES = | ||
PolarisConfiguration.<Long>builder() | ||
.key("METADATA_CACHE_MAX_BYTES") | ||
.description( | ||
"If nonzero, the max size a table's metadata can be in order to be cached in the persistence layer." | ||
+ " If zero, no metadata will be cached or served from the cache. If -1, all metadata will be cached.") | ||
.defaultValue(METADATA_CACHE_MAX_BYTES_NO_CACHING) | ||
.validation(value -> value >= -1) | ||
.build(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this just a safety check? Feels like this shouldn't be able to break right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also isn't this redundant now. (cast calls validate)
So wouldn't this be