-
Notifications
You must be signed in to change notification settings - Fork 988
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 for only v1 is very limiting #70
Comments
Hi @moserke As I mentioned in #3 (comment), #14 (comment) and #30 (comment) there are no plans for supporting alpha/beta at this point in time. The main reason being maintenance burden caused by stability promises (or lack of). In other words we don't have a good way to deal with potential breaking changes (when they come) in a way that it doesn't affect the end user. That said folks maintaining the Google provider are evaluating one approach to this problem (overcoming BCs and supporting multiple versions of APIs) and I plan to circle back after a while to see how it goes (how is the approach accepted/understood by users and devs). Eventually we could apply the same approach here in K8S provider. The idea of supporting alpha/beta certainly isn't shelved - there is no hard line per say. Supporting a few alpha/beta resources right now may look simple, I'm much more concerned about an ongoing support and changing APIs as that's what we have to deal with, as maintainers. We did discuss the idea of some core schema features that would help with this, but other things have higher priority, so there are no immediate plans to make any core changes in this area in the upcoming months. I know it's annoying, but I hope the explanation makes sense. |
Hey @radeksimko! I thought I'd check back and see if you were able to sync with the Google provider team. I've been building around the stuff in there recently and I've done a little bit of work on the provider itself, but can't really speak to what headaches their new versioning support has / hasn't created. I am just about done building out our internal infrastructure stuff around GCP, though, and our next objective will target the actual applications / kubernetes objects we deploy and maintain as admins. One of my primary goals has been to avoid additional layers / templating, if possible, to get us from the heavily-templated multi-stage workflow we have for our AWS stuff today to a single global plan/apply. So far I've gotten by using only Terraform, and I'd love to continue heading in that direction with our applications, but we'd definitely require support for the beta API (at least the workloads) for that to be a possibility. I absolutely don't want to complain – I'm just trying to contextualize, since our window for using this stuff is somewhat narrow. If you think near-term support for multiple API versions is achievable and you're open to contributions, we'd definitely be willing to help build out resources, tackle bugs, etc. Thanks! |
@davidquarles The current way of solving this in GCP provider is expressed here: It's based on whitelisting fields per API version and choosing the API based on the field. I only briefly discussed this with one GCP provider maintainer and I heard mostly positive feedback (from dev's perspective). I think the next step is probably finding all the common patterns between K8S & GCP provider in this area and move some of that code over to Also I'd like to see at least one example of a field transitioning from one API version to another and how it's handled from user's perspective, the GCP provider has not experienced that yet AFAIK. I'd like to focus on building out support for 1.7 and potentially 1.8 before tackling this - there's a bunch of pending PRs and other work. I'll keep you posted. |
Would not provider version lock solve this issue? |
@mishak87 are you thinking of supplying this in the terraform provider configuration, for example hiding it behind a channel flag such as: provider "kubernetes" {
config_context_auth_info = "ops"
config_context_cluster = "mycluster"
api_channel = "stable|alpha|beta " # Default = stable
} As something like that would be faaaannnnntasstic and help keep things stable, for those that require it. |
@matthewhartstonge I would be for no api channel and simply supporting all resources that latest currently supported kubernetes api supports.
provider "kubernetes" {
version = "~> 1.2.0"
}
// using this resource I understand that it might not be available
// in next feature version of kubernetes provider
// and I will have to migrate to stable cronjob_v2 manually in the future
resource "cronjob_v2_alpha1" "cleanup" {
// unicorns rainbows and happiness
} |
Would it be possible to support "generic" kubernetes resource with required field |
@mishak87 excellent approach. The missing resources for Kubernetes is killing our adoption of Terraform for Kubernetes. A generic Kubernetes resource would open many use cases. IMO this feature is one of the most needed of all Terraform providers available. |
Just wanted to provide some updates here, we are working on a plan similar to what @mishak87 described, its still a work in progress as some of the generic handling in |
Did you have any luck with this implementation, @paultyng ? |
Unfortunately I think this provider is ice cold. No progress whatsoever in the last 2 months, despite a lot of effort from the community. Plus it has a lot of preexisting charts (aka modules) https://github.com/kubernetes/charts/tree/master/stable And because helm also uses tiller inside the actual k8s cluster, it's very convenient when you have multiple people managing the cluster. |
@costimuraru What about creating helm provider/module? It would solve plenty of other issues. |
@paultyng or @radeksimko Can you comment on whether work on this provider is still ongoing despite lack of public activity on this repo, or has the effort been dropped? |
@mishak87 There already is a Helm provider, it works well: |
That's actually quite nice! Thanks for sharing @rawkode |
@ktham see this response on the deployments issue: #3 (comment) |
Closing this as we've documented the availability to include Beta resources: https://github.com/terraform-providers/terraform-provider-kubernetes#contributing-resources |
Is there any way to remove the limitation on only resources for v1 APIs? This is incredibly limiting in the kubernetes world as many of the core components of the system live for a long time on alpha & beta APIs. Ingress is a great example of one that is not on v1.
Just wanted to spark conversation around what it would take to be able to support some of these other resources? Or is this just a hard line and there is no way it will be done?
I really want to use this provider and was very excited to see it, but just doesn't fit the bill for that reason.
The text was updated successfully, but these errors were encountered: