-
Notifications
You must be signed in to change notification settings - Fork 80
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
Proposal: Adapt Multiple Type of Database for Harbor #188
base: main
Are you sure you want to change the base?
Conversation
b3e1c80
to
d6a311e
Compare
d6a311e
to
7f05d8f
Compare
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.
Very nice, I like it!
The biggest reason I would like to use MySQL instead of PostgreSQL is that the upgrade process (especially across major versions) is a lot more straightforward in MySQL than it is in PostgreSQL. 😇
The proposal is really cool and I believe there are many community users expecting it! Back to the proposal content, as there are multiple DB supported, do we need to show the DB configurations in the system settings page of the web console? For abstracting the DB differences, have you guys evaluated any DB ORM library like |
I think we don't need to show DB configurations in web console. It is a deployment configuration.
No, still use beego orm. You mean we can use gorm? |
7f05d8f
to
ff74aa5
Compare
I think DB configurations can be shown in web console, but can't edit it in the web.
As @hyy0322 said, we still use beego orm. We can have a discussion about evaluating other DB ORM library like |
@wy65701436 please add your comments here that we just discussed on the Community Meeting! Thank you! |
I'm disappointed to see databases other than PostgreSQL and MySQL being listed as non-goals. For more than a year I've been watching issues related to making CockroachDB available. It's strikes me as unfortunate for a CNCF project to rely on a non-cloud-native datastore. |
@nyarly - Will be great if you can submit such proposal and contribute on it :) Do you have resources to work on proposal for adopting CockroachDB? Will be super happy to see that effort going as well! |
@OrlinVasilev I've been doing the exploratory work to do that, but I'm blocked by dependency issues (c.f. goharbor/harbor#16420) In the meantime, could the scope of the non-intentions be made clear? That this is restricted to this effort, but that other RDBMSes aren't out of scope for the Harbor project? |
I can't speak for @JinXingYoung (so please correct me if this wasn't your intention), but I think the proposal as it reads currently is reasonably clear that it's the goal of this proposal to support MySQL(-like) but that others would also be interesting if we had folks willing to do the work (and maintain it over time):
(Quoted from the intro paragraph of the proposal.) I don't think it hurts to be more clear about the scope of the non-goals section being just this proposal and not the entire project (and your work towards other databases like CockroachDB is definitely appreciated! ❤️), but I don't think that's necessarily unclear as-is either. 👍 |
@nyarly As @nyarly explained, you can join us to support CockroachDB. ❤️ |
ff74aa5
to
04650fc
Compare
Yes, our intention is to support mysql and Mariadb this time, but also to help more databases can be supported. I'll update non-goals clearly to declare that other RDBMSes are welcomed to be supported in as well. |
@JinXingYoung That's great! I've been doing initial work to support Cockroach, and it may be worth discussing overlap; I suspect we're about as much out of TZ sync as we could be, but async communication would work well. I don't want to hijack comments on your proposal arranging that. Can you let me know what would be most convenient for you? Staying on topic, I think it will eventually be the case that Cockroach will need a slightly different DB initialization (like where Harbor currently passes I would love to keep that variation part of the work you're proposing and will be following it avidly. |
I quite agree with you and we'd like to invite you to join our wg. Common issues such as parameter passing and database initialization can use the same logic, and other compatibility issues can also be discussed. We mostly use wechat. You can contact me through email first, so that we can discuss the appropriate way of communication. My email is [email protected]. Maybe our TZ is 16 hours behind you, but as you said, async communication would work well.❤️ |
A meeting will be held via slack channel on March 22 at 10:30AM GMT. Welcome to join us. Meeting Agenda:
Other topics can also be discussed. To join slack channel under CNCF:
|
@nyarly ^^ hope you can join and if anyone from the maintainers can join as well will be great! @tianon @steven-zou @Vad1mo |
😞 sorry didn't see that |
04650fc
to
1b2463f
Compare
1b2463f
to
7f5671d
Compare
7f5671d
to
167c450
Compare
@wy65701436 @tianon @chlins Please help review this PR, thanks ^^ |
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.
- Remove Notary support, as notary is already deprecated.
- I would also suggest removing the migration support, it is not something Harbor should support and maintain.
@Vad1mo Sorry for the late reply, I have been unwell recently. Agreed to remove the notary part. Considering that there may be a need to migrate data from pg to mysql, we provide a migration tool for the data migration part. I think some explanation can be preserved. We can add an explanation that users can choose to use this solution or migrate the data themselves. Is it ok? |
Signed-off-by: JinXingYoung <[email protected]>
47e3f25
to
31a7c36
Compare
I can't see a resolution on the ORM discussion in the thread here, but I'd like to add Ent for consideration. IMO it just beats every other option right now. Regardless of which ORM you decide to go with (if any):
|
This issue has been discussed in the working group before, and ent is the research object, but this revision does not switch the orm library. Later tasks will replace the orm library. |
Thanks for the clarification. |
@Vad1mo Please help me to see if this is OK, thank you.
|
My main concern here is that we create a new tool that we have to maintain in the future that has nothing to do with the core product. So eventually, we will end up with yet another DB migration tool that needs maintenance but does not add any more value than all the other tools out there. Maybe it would be better to create a script using an existing DB migration tool? |
@Vad1mo We discussed the form of data migration tool with community members before, and the conclusion is that Harbor can support more database types in the future. In this time, migration tool development defines a basic framework and after new database types are added, new data migration capabilities can be developed directly based on this framework. |
@Vad1mo Please help to see if this solution is OK? We want to define a general interface so that it can be extended to other db types in the future. |
Signed-off-by: JinXingYoung [email protected]
Follow-up issue: goharbor/harbor#6534