Skip to content
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

[#6078] feat(core): Support model event to Gravitino server #6129

Open
wants to merge 40 commits into
base: main
Choose a base branch
from

Conversation

Abyss-lord
Copy link
Contributor

@Abyss-lord Abyss-lord commented Jan 7, 2025

What changes were proposed in this pull request?

Support model event to Gravitino server. Add list, get, create and delete events to both model and model version.
test case will add after EventDispatcher merged.

ModelInfo, ModelVersionInfo

image

Event

image

Event OperationType ModelCatalog
RegisterModelEvent REGISTER_MODEL registerModel
GetModelEvent LOAD_MODEL getModel
DeleteModelEvent Delete_MODEL deleteModel
ListModelEvent LIST_MODEL listModels
LinkModelVersionEvent LINK_MODEL_VERSION linkModelVersion
GetModelVersionEvent GET_MODEL_VERSION getModelVersion
DeleteModelVersionEvent Delete_MODEL_VERSION deleteModelVersion
ListModelVersionsEvent LIST_MODEL_VERSIONS listModelVersions

ModelEventDispatcher

image

Why are the changes needed?

Fix: #6078

Does this PR introduce any user-facing change?

no

How was this patch tested?

Model Event

  1. testRegisterModelEvent
  2. testGetModelEvent
  3. testDeleteExistsModelEvent
  4. testDeleteNotExistsModelEvent
  5. testListModelEvent

Model Version Event

  1. testLinkModelVersionEvent
  2. testGetModelVersionEventViaVersion
  3. testGetModelVersionEventViaAlias
  4. testDeleteModelVersionEventViaVersion
  5. testDeleteModelVersionEventViaAlias
  6. testDeleteModelVersionEventViaVersionNotExists
  7. testListModelVersionsEvent

@xunliu xunliu requested a review from FANNG1 January 7, 2025 07:33
Support model event to Gravitino server. Add list, get, create and delete events to both model and model version.
@FANNG1
Copy link
Contributor

FANNG1 commented Jan 9, 2025

Will review the PR these days.

LauraXia123 and others added 5 commits January 10, 2025 10:25
…on details page (apache#6167)

### What changes were proposed in this pull request?
Reload tree data after refreshing the version details page
<img width="1352" alt="image"
src="https://github.com/user-attachments/assets/80bc7370-0052-4be8-9b6d-efbe6d97e945"
/>

### Why are the changes needed?
N/A

Fix: apache#6166

### Does this PR introduce _any_ user-facing change?
N/A

### How was this patch tested?
manually
…apache#6159)

### What changes were proposed in this pull request?

1. Refactor catalog commands  and Base class in Gavitino CLI.
2. Add test case.

### Why are the changes needed?

Fix: apache#6143 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test.
…pache#6161)

### What changes were proposed in this pull request?

Refactor table commands in Gavitino CLI and Base class.

### Why are the changes needed?

Fix: apache#6145

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test
…pache#6162)

### What changes were proposed in this pull request?

Refactor model commands and Base class in Gavitino CLI.

### Why are the changes needed?

Fix: apache#6148 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test
…eset catalog with cloud storage (apache#5974)

### What changes were proposed in this pull request?

Support dynamic credential in obtaining cloud storage fileset.

### Why are the changes needed?

Static key are not very safe, we need to optimize it. 

Fix: apache#5973 

### Does this PR introduce _any_ user-facing change?

N/A

### How was this patch tested?

ITs
Copy link
Collaborator

@orenccl orenccl left a comment

Choose a reason for hiding this comment

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

I noticed that this PR includes commits from other PRs. It seems like those are unrelated to the feature in this PR. Could you please clean up the commit history to ensure only relevant changes are included?

justinmclean and others added 12 commits January 11, 2025 10:16
### What changes were proposed in this pull request?

Added LICENSE and NOTICE file for the Trino connector.

### Why are the changes needed?

to comply with ASF policy

Fix: apache#6173

### Does this PR introduce _any_ user-facing change?

No.

### How was this patch tested?

Tested locally.
### What changes were proposed in this pull request?

Update year as we are going to make a new release.

### Why are the changes needed?

ASF/legal policy.

Fix: #N/A

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

N/A
Bumps [nanoid](https://github.com/ai/nanoid) from 3.3.7 to 3.3.8.
<details>
<summary>Changelog</summary>
<p><em>Sourced from <a
href="https://github.com/ai/nanoid/blob/main/CHANGELOG.md">nanoid's
changelog</a>.</em></p>
<blockquote>
<h2>3.3.8</h2>
<ul>
<li>Fixed a way to break Nano ID by passing non-integer size (by <a
href="https://github.com/myndzi"><code>@​myndzi</code></a>).</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="https://github.com/ai/nanoid/commit/3044cd5e73f4cf31795f61f6e6b961c8c0a5c744"><code>3044cd5</code></a>
Release 3.3.8 version</li>
<li><a
href="https://github.com/ai/nanoid/commit/4fe34959c34e5b3573889ed4f24fe91d1d3e7231"><code>4fe3495</code></a>
Update size limit</li>
<li><a
href="https://github.com/ai/nanoid/commit/d643045f40d6dc8afa000a644d857da1436ed08c"><code>d643045</code></a>
Fix pool pollution, infinite loop (<a
href="https://redirect.github.com/ai/nanoid/issues/510">#510</a>)</li>
<li>See full diff in <a
href="https://github.com/ai/nanoid/compare/3.3.7...3.3.8">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=nanoid&package-manager=npm_and_yarn&previous-version=3.3.7&new-version=3.3.8)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)
You can disable automated security fix PRs for this repo from the
[Security Alerts
page](https://github.com/apache/gravitino/network/alerts).

</details>

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
…pache#6174)

### What changes were proposed in this pull request?

Refactor topic commands in Gavitino CLI

### Why are the changes needed?

Fix: apache#6146 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test.
…pache#6175)

### What changes were proposed in this pull request?

Refactor group commands in Gavitino CLI.

### Why are the changes needed?

Fix: apache#6151 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test.
…ages for Iceberg REST server (apache#6168)

### What changes were proposed in this pull request?
1. use Gravitino cloud jar without hadoop packages for Iceberg REST
server credential vending in test and document
2. For OSS, use Gravitino Aliyun bundle jar in test and docker image
because Iceberg doesn't provide Iceberg Aliyun bundle jar


### Why are the changes needed?

Fix: apache#6165 

### Does this PR introduce _any_ user-facing change?
no

### How was this patch tested?
test S3 OSS GCS ADLS Iceberg REST test in local
…operations (apache#6141)

### What changes were proposed in this pull request?

1. for resource path like `a/b`, add "a", "a/", "a/b" read permission
for GCS connector
2. replace `storage.legacyBucketReader` with
`storage.insightsCollectorService`, because `storage.legacyBucketReader`
provides extra list permission for the bucket.

### Why are the changes needed?

Fix: apache#6054 

### Does this PR introduce _any_ user-facing change?
no

### How was this patch tested?
Iceberg GCS IT and fileset GCS credential IT
…apache#6115)

### What changes were proposed in this pull request?

Add document for chain authorization plugin

### Why are the changes needed?

Fix: apache#6110 

### Does this PR introduce _any_ user-facing change?

Just document.

### How was this patch tested?

No need.

---------

Co-authored-by: Xun <[email protected]>
Co-authored-by: Qiming Teng <[email protected]>
…apache#6178)

### What changes were proposed in this pull request?

Refactor schema commands in Gravitino CLI.

### Why are the changes needed?

Fix: apache#6144

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

Local test
### What changes were proposed in this pull request?

Remove the unused protobuf dependency.

### Why are the changes needed?

Since we already removed the KV storage support, so protobuf dependency
is not required any more.

Fix: apache#6184 

### Does this PR introduce _any_ user-facing change?

No.

### How was this patch tested?

Existing tests.
…e#6170)

### What changes were proposed in this pull request? 
Break up role commands in Gravitino command line class

### Why are the changes needed?
For readability and maintainability.

### Fix: apache#6153

### Does this PR introduce any user-facing change?  
None.

### How was this patch tested?
Tested locally.
@Abyss-lord Abyss-lord requested a review from orenccl January 11, 2025 02:20
@Abyss-lord
Copy link
Contributor Author

Abyss-lord commented Jan 11, 2025

I noticed that this PR includes commits from other PRs. It seems like those are unrelated to the feature in this PR. Could you please clean up the commit history to ensure only relevant changes are included?

Hi @orenccl , I’ve finished updating the code. Please take a look at the PR again when you have time.

Copy link
Collaborator

@orenccl orenccl left a comment

Choose a reason for hiding this comment

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

According to #6078, I think we also need to generate event in ModelEventDispatcher and add unit test.

I didn’t see them included in this PR. Could you check?

@Abyss-lord
Copy link
Contributor Author

According to #6078, I think we also need to generate event in ModelEventDispatcher and add unit test.

I didn’t see them included in this PR. Could you check?

@orenccl Thank you! This PR primarily aims to ensure that my design and implementation approach is correct. because this feature is split into 4 issue, If there are no errors, I will add test cases in #6075, WDYT

@orenccl
Copy link
Collaborator

orenccl commented Jan 13, 2025

In my opinion, I would prefer to handle #6075 and #6078 in the same PR.
But I am fine with current approach.

Currently, I am busy with my family as my father is in the hospital's intensive care unit (ICU).
Therefore, I may not be able to respond or review promptly.

I can only perform some simple checks for now. Please reach out to others for help with the review. Thank you!

@orenccl
Copy link
Collaborator

orenccl commented Jan 13, 2025

If you want to handle them separately, please refer to PR #5847 and #5998. I believe these PRs demonstrate how to properly split them into two separate PRs.

And I think we should handle #6075 first, and then handle #6078.

@FANNG1 WDYT?

@Abyss-lord
Copy link
Contributor Author

If you want to handle them separately, please refer to PR #5847 and #5998. I believe these PRs demonstrate how to properly split them into two separate PRs.

And I think we should handle #6075 first, and then handle #6078.

@orenccl Thank you for sharing your thoughts . I appreciate you taking the time to provide feedback despite everything you're going through.Wishing your father a smooth and speedy recovery. I will add ModelEventDispatcher and unit test in this pr.

Take care!!

@FANNG1
Copy link
Contributor

FANNG1 commented Jan 14, 2025

If you want to handle them separately, please refer to PR #5847 and #5998. I believe these PRs demonstrate how to properly split them into two separate PRs.

And I think we should handle #6075 first, and then handle #6078.

@FANNG1 WDYT?

+1 for handle #6075 and #6078 in the same PR. I hope your father is back to healthy soon, Good luck!

Abyss-lord and others added 19 commits January 14, 2025 12:10
…CLI (apache#6188)

### What changes were proposed in this pull request?

Refactor ownership commands in Gravitino CLI.

### Why are the changes needed?

Fix: apache#6177 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test.
…pache#6190)

### What changes were proposed in this pull request?

Refactor column commands CLI

### Why are the changes needed?

Fix: apache#6149 

### Does this PR introduce _any_ user-facing change?

None

### How was this patch tested?

Tested locally
…pache#6193)

### What changes were proposed in this pull request?
Refactor user commands and Base class in Gavitino CLI.

### Why are the changes needed?
Fix: apache#6150 

### Does this PR introduce any user-facing change?
No

### How was this patch tested?
local test.
### What changes were proposed in this pull request?
bump version to 0.9.0-incubating-snapshot

### Why are the changes needed?
change project version after cut branch-0.8

### Does this PR introduce _any_ user-facing change?
no

### How was this patch tested?
no, just change version
## What changes were proposed in this pull request?

Add license and notice files.

### Why are the changes needed?

As the release's content is different to that of Gravitino.

Fix: apache#6194

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

Tested locally.
### What changes were proposed in this pull request?

Fix the wrong document information about revoke roles from role

### Why are the changes needed?

Fix: apache#6069 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

local test.
…utOfBoundsException when execute COMMENT COLUMN command (apache#6182)

### What changes were proposed in this pull request?

Fix the exception of ArrayIndexOutOfBoundsException when handle error
message of IllegalArgumentException

### Why are the changes needed?

Fix: apache#5533 

### Does this PR introduce _any_ user-facing change?

No

### How was this patch tested?

IT
…pache#6137)

### What changes were proposed in this pull request?

Update command usage and add usage tracker

### Why are the changes needed?

So everything is up to date and we can see many many people look up the
CLI docs.

Fix: # N/A

### Does this PR introduce _any_ user-facing change?

No.

### How was this patch tested?

Tested locally.
### What changes were proposed in this pull request?

This PR fixes the glossary docs.

### Why are the changes needed?

The glossary is reordered for quick reference.

### Does this PR introduce _any_ user-facing change?

No.

### How was this patch tested?

N/A
Fix some error and add ModelEventDispatcher to Gravitino server.
…pache#6202)

### What changes were proposed in this pull request?

Add Docker image details for 0.8.0

### Why are the changes needed?

Fix: apache#6200

### Does this PR introduce _any_ user-facing change?

Add doc.

### How was this patch tested?
No need.
…oris table properties. (apache#6186)

### What changes were proposed in this pull request?

Modify table properties SQL in alter table sentence to support setting
table properties.

### Why are the changes needed?

It's a bug.

Fix: apache#5545

### Does this PR introduce _any_ user-facing change?

N/A.

### How was this patch tested?

IT.
…ion in unique index (apache#6183)

### What changes were proposed in this pull request?

 add column not null limitation in unique index

### Why are the changes needed?

mysql will automatically change the null column in unique index to not
null, so we add the limitation at creation

Fix: apache#5721

### Does this PR introduce _any_ user-facing change?

yes, limitation for mysql unique index is more strict

### How was this patch tested?

tests added
…ngine type of MySQL catalog (apache#6209)

### What changes were proposed in this pull request?

Add more details about the usage of engine type for MySQL catalog. 

### Why are the changes needed?

The value of engine type may be influenced by many factors like MySQL
version, configurations and so on, we need to clarify it.

Fix: apache#5100 

### Does this PR introduce _any_ user-facing change?

N/A

### How was this patch tested?

N/A
…tion DDL for paimon-catalog (apache#5818)

### What changes were proposed in this pull request?

Support Catalog Operation DDL for paimon-catalog

### Why are the changes needed?

Fix apache#5192 apache#5193

### Does this PR introduce _any_ user-facing change?

None

### How was this patch tested?


org.apache.gravitino.flink.connector.paimon.TestPaimonPropertiesConverter

org.apache.gravitino.flink.connector.integration.test.paimon.FlinkPaimonCatalogIT
### What changes were proposed in this pull request?

The Gravitino command line class is a little large and could be broken
up.

### Why are the changes needed?

For readability and maintainability.

Fix: apache#6139

### Does this PR introduce _any_ user-facing change?

None.

### How was this patch tested?

Tested locally.

---------

Co-authored-by: Shaofeng Shi <[email protected]>
apache#6191)

### What changes were proposed in this pull request?

Refactor fileset commands in cli client 

### Why are the changes needed?

Fix: apache#6147 

### Does this PR introduce _any_ user-facing change?

None

### How was this patch tested?

Tested locally
…e#6192)

### What changes were proposed in this pull request?

Reduce complexity in `GravitinoCommandLine`

### Why are the changes needed?
For readability and maintainability.

Fix: apache#6152 

### Does this PR introduce _any_ user-facing change?

(Please list the user-facing changes introduced by your change,
including
None.

### How was this patch tested?
Tested locally.

---------

Co-authored-by: Justin Mclean <[email protected]>
@Abyss-lord
Copy link
Contributor Author

Abyss-lord commented Jan 14, 2025

@FANNG1 @shaofengshi I’ve finished updating the code. Please take a look at the PR again when you have time.

throws NoSuchModelException, ModelVersionAliasesAlreadyExistException {
// TODO: preEvent
try {
Model model = dispatcher.getModel(ident);
Copy link
Contributor

Choose a reason for hiding this comment

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

So this seems will do another call to get the model, is it necessary just for generating event?

Copy link
Contributor Author

@Abyss-lord Abyss-lord Jan 15, 2025

Choose a reason for hiding this comment

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

image
@jerryshao thank you, this Just for generating event, IMHO, I think the behavior of preEvent is actually replaced by event and failureEvent, but other entities define preEvent, so should we be consistent with them?

Copy link
Contributor

Choose a reason for hiding this comment

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

Same question with Jerry, seems expensive to do an IO operation to get model to generate event.

…t been refactored

rename drop event and operation type.
// TODO: preEvent
try {
NameIdentifier[] models = dispatcher.listModels(namespace);
eventBus.dispatchEvent(new ListModelEvent(PrincipalUtils.getCurrentUserName(), namespace));
Copy link
Contributor

Choose a reason for hiding this comment

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

ListModelsEvent?

Map<String, String> properties)
throws NoSuchSchemaException, ModelAlreadyExistsException,
ModelVersionAliasesAlreadyExistException {
return dispatcher.registerModel(ident, uri, aliases, comment, properties);
Copy link
Contributor

Choose a reason for hiding this comment

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

missing event here?

try {
boolean isExists = dispatcher.deleteModelVersion(ident, version);
eventBus.dispatchEvent(
new DeleteModelVersionEvent(PrincipalUtils.getCurrentUserName(), ident, isExists));
Copy link
Contributor

Choose a reason for hiding this comment

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

better put version or alias to DeleteModelVersionEvent

try {
int[] versions = dispatcher.listModelVersions(ident);
Model model = dispatcher.getModel(ident);
ModelInfo modelInfo = new ModelInfo(model);
Copy link
Contributor

Choose a reason for hiding this comment

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

no need to place modelInfo to the listModelVersionsEvent

throws NoSuchModelException, ModelVersionAliasesAlreadyExistException {
// TODO: preEvent
try {
Model model = dispatcher.getModel(ident);
Copy link
Contributor

Choose a reason for hiding this comment

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

Same question with Jerry, seems expensive to do an IO operation to get model to generate event.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Subtask] Support model event to Gravitino server