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

[Feature]: Support Jaeger-v2 Helm Chart #534

Closed
yurishkuro opened this issue Jan 8, 2024 · 5 comments
Closed

[Feature]: Support Jaeger-v2 Helm Chart #534

yurishkuro opened this issue Jan 8, 2024 · 5 comments
Labels
enhancement New feature or request

Comments

@yurishkuro
Copy link
Member

Requirement

Once Jaeger-v2 (jaegertracing/jaeger#4843) reaches production readiness and feature parity, we may want to support it in the helm chart.

Problem

Jaeger-v2 is based on OpenTelemetry Collector and uses completely different configuration mechanism:

  • all configuration is done via config files, not CLI flags or env vars (although some env vars are supported by telemetry SDKs)
  • it is a single binary that can be deployed into different roles (collector, query, etc.) also based on configuration, but in this case with structural config changes, not just tweaking parameters

Proposal

I would like to hear what maintainers of this repo think about the best approach. Can we come up with a roadmap of how jaeger-v2 could be supported? Is there some common approach we can use with OTEL (https://github.com/open-telemetry/opentelemetry-helm-charts)?

Parallel ticket for Operator: jaegertracing/jaeger-operator#2411

Open questions

  • Is it worth maintaining both helm charts and operator?
@yurishkuro yurishkuro added the enhancement New feature or request label Jan 8, 2024
@yurishkuro yurishkuro changed the title [Feature]: [Feature]: Support Jaeger-v2 Jan 8, 2024
@yurishkuro
Copy link
Member Author

cc @Stevenpc3 - you recently booked issues, any thoughts on the helm vs. operator question?

@Stevenpc3
Copy link
Contributor

Stevenpc3 commented Jan 18, 2024

Unfortunately for the system I am working in we are currently not able to easily use the operator because our development on the clusters we have get shipped to other (generally air gapped) clusters we don't control and since the operator needs applied at the cluster level with admin it becomes a complex point for us to lose control and synchronize with the other envs we don't control.

So the solutions we develop tend to be as standalone as possible. I personally see a lot of benefits with the operator approaches but we cannot use it. I require the helm charts and will for a long time.

Mostly we make "wrapper" umbrella charts that have the jaeger chart as a dep. So we make like Jaeger-Tracing a chart for example to generate our own templated configs and our own ingress for Istio VS and NGINX and our secret templates and even our own keycloak that we then pass on to the Jaeger chart. Honestly, I would love to get a lot of it into the chart directly, but it's hard to flow it back. We wrap all of the charts because we either use directly which tends to severely lack, we fork and copy which is a nightmare to update or we wrap and do a hybrid to extend the charts. We haven't moved into using operators other than one item so I am not sure how hard it is to extend or wrap or if it's even needed.

I am also behind on the Jaeger V2 since this is only a small part of my overall responsibilities. Plus, I am not sure I get the question lol. I mean both would be nice if that is the question. Let's just say our customers very much need these tools and we are stuck with helm charts for a while.

I just reread and I am not familiar with the opentelemetry-helm-charts ( I just viewed them ) but I do like the idea of a single image and passing only config files. That would be super easy to make a wrapper chart for to generate our own configs. We could make a config.yaml for each (collector, query, etc) and then a template to generate or update that as we need. I am not sure about operators, but this would work well for how we do things.

"Is it worth maintaining both helm charts and operator?" yes. Selfishly as pointed out above. We will be using charts for at the very best case at least another 2 years?

@Stevenpc3
Copy link
Contributor

Stevenpc3 commented May 10, 2024

We are venturing into using operators. I mentioned before we deploy to environments where we don't have control over the Paas we run on or full permissions, but under agreements we expect to be able to apply the CRDs to the cluster then we will likely be able to run operators via namespace restrictions. This is good, but we will still require helm charts. This would mean we would expect to be able to change over to using the jaeger-operator helm chart https://github.com/jaegertracing/helm-charts/tree/main/charts/jaeger-operator in the future.

As we move into a more GitOps approach we will be using ArgoCD now so applying configs is more simple. But we have various environments that get more and more restricted as we proceed right. So there is always a transition period from updating new processes.

I can only thank you for your efforts and your tools and offer a suggestion that deprecation goes a long way towards helping us and others move towards new capabilities, but those capabilities must work or we become stuck in an EOL product because we can't move forward on occasion due to product issues. So, even if the plan is to NOT support certain items... having a deprecation roadmap would be a great option. This gives us the tools to argue for movement.

@yurishkuro yurishkuro changed the title [Feature]: Support Jaeger-v2 [Feature]: Support Jaeger-v2 Helm Chart Aug 31, 2024
@yurishkuro yurishkuro moved this to In Progress in Jaeger V2 Aug 31, 2024
@yurishkuro
Copy link
Member Author

closing as duplicate of #610 (moved from Jaeger repo)

@github-project-automation github-project-automation bot moved this from In Progress to Done in Jaeger V2 Oct 22, 2024
@yurishkuro yurishkuro removed this from Jaeger V2 Oct 22, 2024
@Stevenpc3
Copy link
Contributor

Stevenpc3 commented Nov 16, 2024

I know this is closed, but I feel I never answered the question correctly as perhaps I didn't fully understand.

This threw me off

Image

The answer is yes! Here are some great examples of products that offer a helm chart to deploy their operators that we now use. Some are still being worked on and there are CRD concerns about multiple versions and being up to date etc that are covered in kube docs and 1 and 2 below handle pretty well.

  1. https://github.com/prometheus-community/helm-charts/tree/main/charts/kube-prometheus-stack
  2. https://github.com/elastic/cloud-on-k8s/tree/main/deploy
  3. https://github.com/cloudnative-pg/charts

Here is a comment on an example of someone NOT supplying helm charts and want to force usage of OLM or provide your own. artemiscloud/activemq-artemis-operator#788

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

No branches or pull requests

2 participants