Getting Started • Getting Involved • Getting In Touch
<<<<<<< HEAD ======= >>>>>>> upstream/main
Vision • Design • <<<<<<< HEAD Monitoring ======= Configuration • Monitoring >>>>>>> upstream/main • Performance • <<<<<<< HEAD Security ======= Security >>>>>>> upstream/main • Roadmap
<<<<<<< HEAD This is a repository for OpenTelemetry Collector components that are not suitable for the core repository of the collector.
The OpenTelemetry Collector offers a vendor-agnostic implementation on how to receive, process and export telemetry data. In addition, it removes the need to run, operate and maintain multiple agents/collectors in order to support open-source telemetry data formats (e.g. Jaeger, Prometheus, etc.) to multiple open-source or commercial back-ends.
upstream/main
The official distributions, core and contrib, are available as part of the opentelemetry-collector-releases repository. Some of the components in this repository are part of the "core" distribution, such as the Jaeger and Prometheus components, but most of the components here are only available as part of the "contrib" distribution. Users of the OpenTelemetry Collector are also encouraged to build their own custom distributions with the OpenTelemetry Collector Builder, using the components they need from the core repository, the contrib repository, and possibly third-party or internal repositories.
Each component has its own support levels, as defined in the following sections. For each signal that a component supports, there's a stability level, setting the right expectations. It is possible then that a component will be Stable for traces but Alpha for metrics and Development for logs.
Stability level for components in this repository follow the definitions from the OpenTelemetry Collector repository.
Some features are hidden behind feature gates before they are part of the main code path for the component. Note that the feature gates themselves might be at different lifecycle stages.
Each component is supported either by the community of OpenTelemetry Collector Contrib maintainers, as defined by the GitHub group @open-telemetry/collector-contrib-maintainer, or by specific vendors. See the individual README files for information about the specific components.
The OpenTelemetry Collector Contrib maintainers may at any time downgrade specific components, including vendor-specific ones, if they are deemed unmaintained or if they pose a risk to the repository and/or binary distribution.
Even though the OpenTelemetry Collector Contrib maintainers are ultimately responsible for the components hosted here, actual support will likely be provided by individual contributors, typically a code owner for the specific component.
The collector components and implementation are in different stages of stability, and usually split between functionality and configuration. The status for each component is available in the README file for the component. While we intend to provide high-quality components as part of this repository, we acknowledge that not all of them are ready for prime time. As such, each component should list its current stability level for each telemetry signal, according to the following definitions:
Not all pieces of the component are in place yet and it might not be available as part of any distributions yet. Bugs and performance issues should be reported, but it is likely that the component owners might not give them much attention. Your feedback is still desired, especially when it comes to the user-experience (configuration options, component observability, technical implementation details, ...). Configuration options might break often depending on how things evolve. The component should not be used in production.
The component is ready to be used for limited non-critical workloads and the authors of this component would welcome your feedback. Bugs and performance problems should be reported, but component owners might not work on them right away. The configuration options might change often without backwards compatibility guarantees.
Same as Alpha, but the configuration options are deemed stable. While there might be breaking changes between releases, component owners should try to minimize them. A component at this stage is expected to have had exposure to non-critical production workloads already during its Alpha phase, making it suitable for broader usage.
The component is ready for general availability. Bugs and performance problems should be reported and there's an expectation that the component owners will work on them. Breaking changes, including configuration options and the component's output are not expected to happen without prior notice, unless under special circumstances.
The component is planned to be removed in a future version and no further support will be provided. Note that new issues will likely not be worked on. When a component enters "deprecated" mode, it is expected to exist for at least two minor releases. See the component's readme file for more details on when a component will cease to exist.
A component identified as unmaintained does not have an active code owner. Such component may have never been assigned a code owner or a previously active code owner has not responded to requests for feedback within 6 weeks of being contacted. Issues and pull requests for unmaintained components will be labelled as such. After 6 months of being unmaintained, these components will be removed from official distribution. Components that are unmaintained are actively seeking contributors to become code owners.
When used as a library, the OpenTelemetry Collector attempts to track the currently supported versions of Go, as defined by the Go team. Removing support for an unsupported Go version is not considered a breaking change.
Starting with the release of Go 1.18, support for Go versions on the OpenTelemetry Collector will be updated as follows:
- The first release after the release of a new Go minor version
N
will add build and tests steps for the new Go minor version. - The first release after the release of a new Go minor version
N
will remove support for Go versionN-2
.
Official OpenTelemetry Collector distro binaries may be built with any supported Go version.
See the Contributing Guide for details.
<<<<<<< HEAD Triagers (@open-telemetry/collector-contrib-triagers)
- Andrzej Stencel, Sumo Logic
- Benedikt Bongartz, Red Hat
- Goutham Veeramachaneni, Grafana
- Actively seeking contributors to triage issues
Here is a list of community roles with current and previous members:
upstream/main
- Triagers (@open-telemetry/collector-triagers):
<<<<<<< HEAD Approvers (@open-telemetry/collector-contrib-approvers):
- Anthony Mirabella, AWS
- Antoine Toulme, Splunk
- David Ashpole, Google
- Evan Bradley, Dynatrace
- Ruslan Kovalov, Grafana Labs
- Sean Marciniak, Atlassian
- Ziqi Zhao, Alibaba
Emeritus Approvers:
Maintainers (@open-telemetry/collector-contrib-maintainer):
- Alex Boten, Lightstep
- Bogdan Drutu, Splunk
- Daniel Jaglowski, observIQ
- Dmitrii Anoshin, Splunk
- Juraci Paixão Kröhling, Grafana Labs
- Pablo Baeyens, DataDog
- Tyler Helmuth, Honeycomb
Emeritus Maintainers
-
Tigran Najaryan, Splunk =======
- Actively seeking contributors to triage issues
-
Emeritus Triagers:
- Andrew Hsu, Lightstep
- Alolita Sharma, Apple
- Punya Biswal, Google
- Steve Flanders, Splunk
-
Approvers (@open-telemetry/collector-approvers):
upstream/main
-
Anthony Mirabella, AWS
-
Daniel Jaglowski, observIQ
-
Juraci Paixão Kröhling, Grafana Labs
-
Pablo Baeyens, DataDog
-
Emeritus Approvers:
- James Bebbington, Google
- Jay Camp, Splunk
- Nail Islamov, Google
- Owais Lone, Splunk
- Rahul Patel, Google
- Steven Karis, Splunk
- Yang Song, Google
-
Maintainers (@open-telemetry/collector-maintainers):
- Alex Boten, Lightstep
- Bogdan Drutu, Splunk
- Dmitrii Anoshin, Splunk
-
Emeritus Maintainers:
- Paulo Janotti, Splunk
- Tigran Najaryan, Splunk
Learn more about roles in Community membership. In addition to what is described at the organization-level, the SIG Collector requires all core approvers to take part in rotating the role of the release manager.
When creating a PR please following the process described here.
News PRs will be automatically associated with the reviewers based on CODEOWNERS. PRs will be also automatically assigned to one of the maintainers or approvers for facilitation.
The facilitator is responsible for helping the PR author and reviewers to make progress or if progress cannot be made for closing the PR.
If the reviewers do not have approval rights the facilitator is also responsible for the official approval that is required for the PR to be merged and if the facilitator is a maintainer they are responsible for merging the PR as well.
The facilitator is not required to perform a thorough review, but they are encouraged to enforce Collector best practices and consistency across the codebase and component behavior. The facilitators will typically rely on codeowner's detailed review of the code when making the final approval decision.
We recommend maintainers and approvers to keep an eye on the project board. All newly created PRs are automatically added to this board. (If you don't see the PR on the board you may need to add it manually by setting the Project field in the PR view).