- Welcome
- Ways to Contribute
- Find an Issue
- Issue Guidelines
- Pull Request Guidelines
- Communication
- Code Review Process
- Testing Requirements
- Code of Conduct
- License
- Local Development
- Odiglet
- Instrumentor
Welcome! We are glad that you want to contribute to our project! 💖
As you get started, you are in the best position to give us feedback on areas of our project that we need help with, including:
- Problems found during setting up a new developer environment
- Gaps in our Quickstart Guide or documentation
- Bugs in our automation scripts
If anything doesn't make sense, or doesn't work when you run it, please open a bug report and let us know!
There are many ways to contribute to the Odigos project:
- New Features: Suggest or implement new features that can improve the project. Provide as much context and detail as possible to help us evaluate your idea.
- Builds and CI/CD: Help enhance the build pipelines or improve CI/CD workflows to ensure smoother development processes.
- Bug Fixes: Identify and fix bugs. Make sure to document the issue and verify your fixes with appropriate tests.
- Documentation: Improve existing documentation, fix typos, or write new guides and tutorials to help contributors and users.
- Issue Triage: Assist with categorizing, labeling, and prioritizing issues to streamline the workflow.
- Answering Questions: Participate in discussions on Slack or mailing lists to help community members.
- Web Design: Contribute to the design and UX of project-related websites or dashboards.
- Communications, Social Media, and Blog Posts: Help create content for social media, blogs, or other channels to promote the project and engage with the community.
- Release Management: Assist in preparing, testing, and documenting releases to ensure smooth rollouts.
Every contribution, big or small, is greatly appreciated and helps make Odigos better for everyone!
We have good first issues for new contributors and help wanted issues suitable for any contributor. good first issue has extra information to help you make your first contribution. help wanted are issues suitable for someone who isn't a core maintainer and is good to move onto after your first pull request.
Sometimes there won’t be any issues with these labels. That’s ok! There is likely still something for you to work on.
Once you see an issue that you'd like to work on, please post a comment saying that you want to work on it. Something like "I want to work on this" is fine.
When reporting an issue:
- Use a clear and descriptive title.
- Include detailed steps to reproduce the issue.
- Share relevant logs, configurations, or screenshots.
- Label the issue appropriately (e.g., bug, feature request, enhancement).
When submitt
- Include a clear description of the change and its purpose.
- Link to any related issues or documentation.
- Add tests to cover new functionality or fix existing ones.
- Ensure your branch is up to date with the main branch.
If you have questions or need help:
- Join our Slack Community.
- Post questions or ideas in our GitHub Discussions.
- Email the core maintainers at [email protected].
All contributions will go through the following review process:
- A maintainer will review your pull request within 3-5 business days.
- Feedback will be provided for improvements, if necessary.
- Once approved, your pull request will be merged into the main branch.
- Larger changes may require discussion in a GitHub issue or pull request thread.
- We are available on Slack to discuss any issues regarding the PR process or general contributions.
Tests will run automatically in CI (Continuous Integration) and must pass for the pull request to be merged.
We expect all contributors to follow our Code of Conduct. This ensures a welcoming, inclusive, and respectful community for everyone.
By contributing, you agree that your contributions will be licensed under the project's Apache License.
This section describes how to setup your local development environment and test your code changes.
First, follow the Quickstart Guide in odigos docs to create a local k8s development cluster with a demo application and a functioning odigos installation.
Make sure you are able to:
- run Odigos CLI in your terminal.
- open the demo application UI in your browser to interact with it.
- install odigos in your development cluster with
odigos install
. - open Odigos UI in your browser to interact with it.
- see telemetry data that odigos generates, for example traces in jaeger.
After you have a working odigos setup, you can start making changes to the code and test them locally.
The code for the odigos cli tool is found in the cli
directory here.
Test your cli code changes by running the following:
go run -tags=embed_manifests ./cli
To run odigos install
cli command from a local source, use the make command from repo root:
make cli-install
# Installing Odigos version v0.1.81 in namespace odigos-system ...
If you test changes to the install
command, you will need to odigos uninstall
first before you can run install again.
The main steps involved when debugging Odigos locally are:
- Use a Kind kubernetes cluster.
- Choose one of the following options for deploy:
- Deploy all pods in the odigos-system namespace:
make deploy
- Deploy a specific service by running one of the following commands:
make deploy-odiglet
make deploy-autoscaler
make deploy-collector
make deploy-scheduler
make deploy-instrumentor
make deploy-ui
- Deploy odiglet and build instrumentation agents from source code:
First - make sure you clone the nodejs agent repos in the same directory as the odigos repo. e.g. ../opentelemetry-node
should exist alongside the odigos repo in your local filesystem.
To deploy odiglet with agents from this source directory:
make deploy-odiglet-with-agents
See the Odigos docs for the full steps on debugging Odigos locally.
Build the frontend
cd frontend/webapp
yarn install
yarn build
yarn dev
cd ../.. # back to root of the project for next steps
Then run the web server
cd frontend
go build -o odigos-backend && ./odigos-backend --port 8085 --debug --address 0.0.0.0
Odiglet Dockerfile uses a base image for the builder, which saves up lots of time during builds. The Dockerfile for the base image can be found in ./odiglet/base.Dockerfile
and is consumed like so: FROM keyval/odiglet-base:v1.0 as builder
If you need to add additional packages to the build, update this file. Then publish the new base image to dockerhub with the github action named Publish Odiglet Base Builder
in the Actions
tab.
You will need to specify the new image tag as a version in the format v1.0
.
After the image is published, update the dependency in ./odiglet/Dockerfile
to use the new image tag.
First, you will have to find which version of Odigos you are running. You can do this by running odigos version
in your terminal.
Then, run the following command to build Odiglet in debug mode and restart the Odiglet pod:
make debug-odiglet
Then, you can attach a debugger to the Odiglet pod. For example, if you are using Goland, you can follow the instructions here to attach to a remote process.
For Visual Studio Code, you can use the .vscode/launch.json
file in this repo to attach to the Odiglet pod.
If the Mutating Webhook is enabled, follow these steps:
- Copy the TLS certificate and key: Create a local directory and extract the certificate and key by running the following command:
mkdir -p serving-certs && kubectl get secret instrumentor-webhook-cert -n odigos-system -o jsonpath='{.data.tls\.crt}' | base64 -d > serving-certs/tls.crt && kubectl get secret instrumentor-webhook-cert -n odigos-system -o jsonpath='{.data.tls\.key}' | base64 -d > serving-certs/tls.key
- Apply this service to the cluster, it will replace the existing
odigos-instrumentor
service:
apiVersion: v1
kind: Service
metadata:
name: odigos-instrumentor
namespace: odigos-system
spec:
type: ExternalName
externalName: host.docker.internal
ports:
- name: webhook-server
port: 9443
protocol: TCP
Once this is done, you can use the .vscode/launch.json configuration and run instrumentor local for debugging.
It is sometimes necessary to look at the data flowing through the collector pipeline while debugging or troubleshooting. This can be done by adding a debug destination to the collector configuration.
This collector will write 2 telemetry items per second to the cluster collector logs.
make dev-debug-destination
It you want to have the pipeline but don't want to send data anywhere, use the nop destination:
make dev-nop-destination