Getting started | Main commands | Generate Doc & Code | Architecture | Change log | Contributing | Links |
Note
Codegen authors, please refer to the following documentation to learn how to use Weaver for generating code from semantic conventions:
OTel Weaver is a comprehensive tool designed to enable developers to easily develop, validate, document, and deploy semantic conventions (phase 1) and application telemetry schemas (phase 2). As an open, customizable, and extensible platform, it aims to serve both as a standalone developer tool and as an integral component within CI/CD pipelines—whether for the OpenTelemetry project itself, other open-source projects, vendor solutions, or even large-scale enterprise deployments leveraging OpenTelemetry.
- Semantic conventions enable SMEs to define a catalog of well-defined and reusable attributes and signals. OpenTelemetry maintains an official Semantic Convention Registry that any project can leverage for consistent instrumentation. Open-source projects, vendors, and enterprises can also implement their own registries for specific needs, which Weaver can import and resolve to cover all instrumented components of complex systems.
- Application Telemetry Schema allows developers to specify the semantic convention registries and custom attributes and signals supported by their applications. The vision behind this concept is detailed in this document, with implementation planned for Weaver's phase 2.
Weaver is built upon principles of extensibility, customizability, scalability, robustness, reliability, and cross-platform compatibility.
- Schema Resolution: The Weaver Resolver sub-project resolves references, extends clauses, and overrides in semantic convention registries and application telemetry schemas, producing self-contained, easy-to-process, and shareable resolved schemas.
- Policy Enforcement: The Weaver Checker sub-project ensures the quality, maintainability, and extensibility of registries and schemas by checking them against a set of declarative policies using the popular rego policy language.
- Documentation and Code Generation: The Weaver Forge sub-project generates
documentation and code from registries and schemas. It leverages a jq-compatibleexpression language for data transformation and ajinja2-compatibletemplate engine for output generation.
- WASM-based Plugin System (future plan): A plugin system based on WASM will be implemented to extend the Weaver platform. Plugins could be designed to download registries and schemas from custom systems, feed data catalog solutions, or configure dashboard systems, among other functionalities.
- Built with Rust, Weaver offers performance comparable to C or C++ implementation. The entire OpenTelemetry semantic convention registry can be downloaded, resolved, and documented in under 2 seconds.
- Semantic Convention Registry Git repositories can be efficiently cached locally.
- Registry and schema validation, as well as documentation and code generation, are parallelized for optimal performance.
- Memory Safety: Rust ensures memory safety, preventing common vulnerabilities.
- Comprehensive Error Reporting: Weaver reports as many errors as possible in a single pass, providing developers with comprehensive feedback.
- Quality Assurance: Code coverage, Cargo deny, Dependabot, and automated security audits.
- Tested Platforms: Weaver is manually tested on Linux, macOS, and Windows.
- Future Plans: Automated tests will be implemented for broader platform coverage.
Currently, weaver can be consumed in one of three ways:
Weaver release attach pre-built binaries for supported platforms with every release. Instructions for installing are included in these release notes.
See: Weaver Releases
Weaver deploys a docker image for development to docker hub.
Instructions for using the docker image can be found here.
To install the tool from source. you need to have Rust installed on your system (see Install Rust).
To build the tool:
- In debug mode, run the following command:
cargo build
- In release mode, run the following command:
cargo build --release
The generated weaver binary will be located in the target/debug directory
for debug mode or the target/release directory for release mode.
To run a registry check, use the following command:
cargo run -- registry check
This command will check the OpenTelemetry Semantic Convention Registry by default.
To check a set of policies against the registry, use the following command:
cargo run -- registry check -b path/to/policies
An example of a policy file can be found here schemas/otel_policies.rego.
In phase 1, the only supported commands are related to the management of Semantic Convention Registries. The following commands are available:
| Command | Description | 
|---|---|
| weaver registry check | Check the validity of a semconv registry | 
| weaver registry resolve | Resolve a semconv registry | 
| weaver registry diff | Generate a diff report between two versions | 
| weaver registry generate | Generate artifacts from a semconv registry | 
| weaver registry update-markdown | Update semconv snippet-based markdown files | 
| weaver registry stats | Generate statistics on a semconv registry | 
Phase 2 will introduce commands related to the management of Application Telemetry Schemas.
- Weaver Architecture: A document detailing the architecture of the project.
- Weaver Configuration: A document detailing the configuration options available.
- Weaver Forge: An integrated template engine designed to generate documentation and code based on semantic conventions.
- Weaver Checker: An integrated policy engine for enforcing policies on semantic conventions.
- Schema Changes: A document describing the data model used to represent the differences between two versions of a semantic convention registry.
- Application Telemetry Schema OTEP: A vision and roadmap for the concept of Application Telemetry Schema.
- Presentation slides from the Semantic Convention SIG meeting on October 23, 2023 here.
The following examples show how to generate code and documentation for various languages using Weaver.
Note: A more out of the box experience will be available in the future.
Java From GitHub repo main branch.
weaver registry generate \
--templates https://github.com/open-telemetry/semantic-conventions-java.git[buildscripts/templates] \
javaC++ From a specific release using the corresponding archive.
weaver registry generate \
--templates https://github.com/open-telemetry/opentelemetry-cpp/archive/refs/tags/v1.20.0.zip[buildscripts/semantic-convention/templates] \
./ \
--param filter=any \
--param output=output/ \
--param schema_url=https://opentelemetry.io/schemas/v1.32.0Python From GitHub repo main branch.
weaver registry generate \
--templates https://github.com/open-telemetry/opentelemetry-python.git[scripts/semconv/templates] \
--param output=./ \
--param filter=any \
./Markdown (attribute registry) From a specific release using a GitHub archive release.
weaver registry generate \
--templates https://github.com/open-telemetry/semantic-conventions/archive/refs/tags/v1.32.0.zip[templates] \
markdownTemplates in local path
weaver registry generate \
--templates custom-templates/ \
markdown- Component Telemetry Schema (proposal)
- Resolved Telemetry Schema (proposal)
- OpenTelemetry Telemetry Schema v1.2.0 Draft ( not yet ready).
Weaver supports shell completions via clap_complete for the following shells: bash, elvish, fish, powershell, and zsh. Installing and using the completion depends on your shell, and your setup.
For example, to install the completion for bash, you can run the following command:
weaver completion bash > $BASH_COMPLETION_USER_DIR/weaverTo enable the completion for zsh, you can run the following command:
weaver completion zsh > ${fpath[1]}/_weaverThat will install the completion in the first directory in your fpath array.
- OpenTelemetry Semantic Convention File Format
- OpenTelemetry Schema File Format v1.1.0
- Meta/Facebook's positional paper presenting a similar approach but based on Thrift+Annotations+Automations.
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change. For more information, please read CONTRIBUTING.
OpenTelemetry Weaver is licensed under Apache License Version 2.0.