-
Notifications
You must be signed in to change notification settings - Fork 517
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
Allow option to create opentelemetry-collector CR along with otel-operator helm installation #69
Comments
I think using pre-install mechnism is an appropriate workaround if you want to "create otelcol CR along with the otel operator installation". If you can accept Collector to be installed slight after the Operator's readiness, I think |
But how can I use I'm adding a otel-col CR inside |
If you install the CR before the hook is installed, your CR will not be validated and we might not normalize it (defaulter). Not sure how to do it with Helm, but you do need to create the CR after the operator is ready. |
I am trying to create otel-col in deployment mode. So the validating webhook has very little to do with type deployment as more validations logic is on other types of deployment modes. And mutating webhook is responsible for injecting the labels It works for now. But I know adding new functionality into operator webhooks will definitely break this. :) And I am not sure of any other alternatives to include otel-col CR within the otel-operator helm installation. :/ |
It might be a short-term solution for you, but we definitely need a proper solution for the wider community. |
Isn't this more of an issue with helm/your release process, than an issue with this chart? (though, if your I think its generally recommended to not tie together the CRD and CR in the same chart (see Helm's docs on this topic and its caveats -- specifically that bit about unintentional data loss).
... which is why I generally prefer Method 2 - Separate Charts. Precisely how to make that happen in a single step depends on your release system, which is why I think its not exactly an issue with this chart. For example in my case I can use ArgoCD sync waves to ensure the CRD is stood up in a way that admission/validation webhooks fire correctly by the time I install the relevant |
@mars64 thanks for the input. But dealing with separate charts makes it more complex right? I mean the upgrades and management of multiple charts, which represent a single system i.e. the actual components and the supporting components. |
The way I read your request, the complexity comes from the goal of combining two different resources (CRD and the CR that relies on the CRD -- each with different lifecycles) into a single step (i.e. install a single helm chart). I'm trying to point out that the helm community generally doesn't seem to have a good answer for this. In other words, it's additional complexity either way. Personally, I think its less complex to rely on two different charts that more directly serve their purposes, than to attempt to make a chart designed for the CRD lifecycle also responsible for the lifecycle of what is potentially many CR's depending on the use case. This is why I mentioned my use of ArgoCD sync waves to control CRD and CR installation in separate charts but in a single "installation step". I'd love to hear if your or others have had success to the contrary! |
I like the method 2 with separate helm charts, but not sure what's the established practice in other helm charts out there |
Any updates here? I'm running in to the same problem now (as described here) |
For context, the kube-prometheus-stack helm chart is able to install the CRDs and an instance of a |
I don't think anyone is working on it. Any help would be appreciated |
@TylerHelmuth I think this is still open in the operator world, I don't have a lot of cycles right now to work on fixing this, but can bring this up at the next operator SIG and see if someone else does. |
@jaronoff97 sounds good. I can dedicate cycles to this as well I think. |
@jaronoff97 @VineethReddy02 I'm really interested in the use cases for having the CR's as part of the operator chart. In the case of kube-prometheus-stack the bundle makes sense as the core prometheus/alertmanager config is pretty generic and the custom config is handled in decoupled CR's (servicemonitor/prometheusrule). We use both kube-prometheus-stack and otel-operator in different setups:
For otel-operator I see 3 as the best option or 1 if you'd want to replace Prometheus cluster monitoring with a collector+several backends. I believe this chart is trying to achieve 1. |
Bumped into the same problem. After reading comments by @mars64, I wanted to pitch in a clarification that this problem isn't the classic "CRD must be installed before CR" scenario. For me it's caused by the operator's webhook not yet being ready when the CR is applied (when the operator and CR are both installed in the same release). Outline of the sequential steps in my CI/CD pipeline:
apiVersion: v2
name: opentelemetry
type: application
version: 1.0.0
- name: opentelemetry-operator
version: 0.30.0
repository: https://open-telemetry.github.io/opentelemetry-helm-charts/
apiVersion: opentelemetry.io/v1alpha1
kind: OpenTelemetryCollector
metadata:
name: opentelemetry
spec:
mode: deployment
config: |
receivers:
otlp:
protocols:
grpc:
http:
processors:
exporters:
logging:
service:
pipelines:
traces:
receivers: [otlp]
processors: []
exporters: [logging] Ideally I'd like to deploy the operator and instantiate an operand in the same release, but the only reasonable workaround I can think of is to have them in separate releases/charts 😢 |
I am currently evaluating opentelemetry-operator helm chart. I am stuck on an issue. I wanted to add the opentelemetry-collector custom resource along with otel-operator helm chart installation.
The otel-col CR creation fails during installation with the below error:
Because the CR creation triggers the mutating webhook request to the operator and on creating otel-col CR during installation the otel-operator is still in the container creating phase, so the CR creation is failing. Is there any solution to fix this issue? I want to create otelcol CR along with the otel operator installation.
As a workaround, I am installing otel-col CR alongside otel-operator installation by adding helm
pre-install
webhook to create otel-col CR prior to the creation of webhooks and I am myself adding the otel-col default mode as deployment and labels that are configured using mutating webhook as belowAre there any alternative solutions to do this? Is my workaround an appropriate fix?
cc @Saber-W @jpkrohling
The text was updated successfully, but these errors were encountered: