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

Alter database option #4394

Closed
killme2008 opened this issue Jul 18, 2024 · 11 comments
Closed

Alter database option #4394

killme2008 opened this issue Jul 18, 2024 · 11 comments
Assignees
Labels
C-feature Category Features

Comments

@killme2008
Copy link
Contributor

What problem does the new feature solve?

Since v0.8, GreptimeDB supports database TTL just like:

CREATE DATABASE test with(ttl='7d');

which means all the tables in this database will inherit this option if they don't have their own TTL setting.

It does not support alerting the options after they are created.

What does the feature do?

Alter the database options:

Alter database test set ttl = '14d`;

Implementation challenges

No response

@killme2008 killme2008 added the C-feature Category Features label Jul 18, 2024
@NiwakaDev
Copy link
Collaborator

I'm interested in this issue. I guess we can implement this feature with the following high level steps.

  1. Allow parser to handle sql like ALTER DATABASE test SET ttl = '14d'.
  2. Implement AlterDatabaseProcedure. (I guess that greptimedb doesn't support this yet.) This procedure should alter the ttl for every inherited table(region) in a database, and then also alter the database ttl.

@killme2008
Copy link
Contributor Author

killme2008 commented Jul 23, 2024

Cool. @NiwakaDev

Allow parser to handle sql like ALTER DATABASE test SET ttl = '14d'.

I recommend designing the statement to use set OPTIONS(ttl='14d') since we might need to SET other things in the future. Introducing the OPTIONS keyword is more beneficial. The use of parentheses () allows for batch setting of options, for example:

alter database set options ('ttl'='14d', 'compaction.time_window'='1d');

Implement AlterDatabaseProcedure. (I guess that greptimedb doesn't support this yet.) This procedure should alter the ttl > for every inherited table(region) in a database, and then also alter the database ttl.

Yes, you have to implement a procedure, which needs to change the database metadata. I am not quite sure if we need to alter all the inherited table options too, because:

  1. We don't have a value to represent if the option is inherited or defined by table DDL.
  2. It requires the table to support alter table set options, but it doesn't Alter table options #1084

What do you think? @evenyag @fengjiachun

@evenyag
Copy link
Contributor

evenyag commented Jul 23, 2024

alter database test options ('ttl'='14d', 'compaction.time_window'='1d');

Looks good.

It requires the table to support alter table set options, but it doesn't

Should table options have higher priority than database options?

@fengjiachun
Copy link
Collaborator

It requires the table to support alter table set options, but it doesn't

I think alter database relying on table options might not be a good idea. Because synchronizing and modifying all table options when executing alter database options could involve a large number of table modifications.

My idea is that alter database options should only update the database metadata. When the region GC worker operates, it retrieves the TTL of the database from DatabaseMetadataManager, merges it with the region's TTL to get the minimum value, and then continues its task.

Right now, we don't have a DatabaseMetadataManager, but that's not a big issue. We just need to wrap the KvBackend, and then we can get the TTL value of database from metasrv.

@NiwakaDev
Copy link
Collaborator

@fengjiachun

When the region GC worker operates, it retrieves the TTL of the database from DatabaseMetadataManager, merges it with the region's TTL to get the minimum value, and then continues its task.

Aren't there any situations where we want to prioritize the table ttl even if the database ttl is smaller?

@evenyag
Copy link
Contributor

evenyag commented Jul 24, 2024

@fengjiachun

When the region GC worker operates, it retrieves the TTL of the database from DatabaseMetadataManager, merges it with the region's TTL to get the minimum value, and then continues its task.

Aren't there any situations where we want to prioritize the table ttl even if the database ttl is smaller?

I think the region's TTL option should have higher priority. It overwrites the database's TTL if we set the table TTL.
@fengjiachun What do you think?

@killme2008
Copy link
Contributor Author

killme2008 commented Jul 25, 2024

Of course, the table's custom TTL must be prioritized over the database TTL.

However, the table TTL is set to the database TTL when creating a table without the ttl table option.

table_opts.ttl = table_opts.ttl.or(schema_opts.ttl);

We don't know if a table is inherited or custom the TTL at all. There is one solution is that we can add a flag to figure out that the table TTL is merged from database TTL, and then while altering database TTL, we can change these tables(regions) TTL too.

Another choice is as @fengjiachun said, let's not change the region's TTL but just the database options. I prefer the second solution. It's much simpler, and altering many tables is expensive.

@NiwakaDev
Copy link
Collaborator

Another choice is as @fengjiachun said, let's not change the region's TTL but just the database options. I prefer the second solution. It's much simpler, and altering many tables is expensive.

Even if we choose the choice, I think we still need a flag indicates whether or not the table is inherited. I guess that adding the flag isn't expensive.

When the region GC works, if the flag is set, we prioritize the table TTL. Otherwise, we select the database TTL from the DatabaseMetadataManager.

@killme2008
Copy link
Contributor Author

Another choice is as @fengjiachun said, let's not change the region's TTL but just the database options. I prefer the second solution. It's much simpler, and altering many tables is expensive.

Even if we choose the choice, I think we still need a flag indicates whether or not the table is inherited. I guess that adding the flag isn't expensive.

Agree, let's add a flag to indicate whether or not the table option is inherited. Maybe it's an option set like inherited_options.

When the region GC works, if the flag is set, we prioritize the table TTL. Otherwise, we select the database TTL from the DatabaseMetadataManager.

Sound good. Then it doesn't need to alter all the table options, but just retrieving the database TTL while gc.

@NiwakaDev
Copy link
Collaborator

NiwakaDev commented Jul 26, 2024

I'll implement this feature with the following high level steps:

  • Implement DatabaseMetadataManager.
  • Implement AlterDatabaseProcedure.
  • Allow parser to handle sql like alter database set options ('ttl'='14d', ~);.

@NiwakaDev NiwakaDev self-assigned this Jul 29, 2024
@NiwakaDev
Copy link
Collaborator

Sorry for the delay in implementing this. I'll submit a first PR next week.

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

No branches or pull requests

5 participants