Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liurui-software/ojr
OJR (OpenTelemetry Receivers by Java)
https://github.com/liurui-software/ojr
apm monitoring monitoring-agents observability opentelemetry opentelemetry-collector opentelemetry-java opentelemetry-receivers
Last synced: about 1 month ago
JSON representation
OJR (OpenTelemetry Receivers by Java)
- Host: GitHub
- URL: https://github.com/liurui-software/ojr
- Owner: liurui-software
- License: apache-2.0
- Created: 2024-12-18T07:27:02.000Z (about 1 month ago)
- Default Branch: main
- Last Pushed: 2024-12-19T16:45:20.000Z (about 1 month ago)
- Last Synced: 2024-12-19T17:38:45.737Z (about 1 month ago)
- Topics: apm, monitoring, monitoring-agents, observability, opentelemetry, opentelemetry-collector, opentelemetry-java, opentelemetry-receivers
- Language: Java
- Homepage:
- Size: 4.06 MB
- Stars: 27
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# OJR (OpenTelemetry Receivers by Java)
**[Changelog](CHANGELOG.md)** | **[Semantic Conventions](docs/semconv/README.md)** | **[Contributing](CONTRIBUTING.md)** | **[License](LICENSE)**
---## Introduction of OJR
OJR ([OpenTelemetry](https://opentelemetry.io/) [Receivers](https://opentelemetry.io/docs/collector/configuration/#receivers) by Java) is a collection of stanalone OpenTelemetry receivers written with Java. A standard [OTLP](https://opentelemetry.io/docs/specs/otel/protocol/) [exporter](https://opentelemetry.io/docs/collector/configuration/#exporters) is provided to forward the data from the receivers to a Telemetry backend or an [OpenTelemetry Collector](https://opentelemetry.io/docs/collector/).
OpenTelemetry's goals are real and its realization has a realistic basis, although the problems it has to solve are indeed complex. The achievement of OpenTelemetry is amazing. The number of users is also increasing significantly. However, there are still challenges along with the design of OpenTelemetry. One problem is the over-complexity of some of the SDKs, which creates obstacles to the efforts of product vendors to include support for OpenTelemetry. The auto-instrumentation is really good while sometimes we still need manual enhancements from the product or app providers to add built-in OpenTelemetry support. There are other minor issues. For example, OpenTelemetry Collector is a fantastic tool. While small or medium systems can be difficult to be selected to have an official receiver inside the official released OpenTelemetry Collectors.
There are several goals of this project:
- Provide a simplified SDK for Java developers to adopt OpenTelemetry.
- Provide standalone receivers for diverse systems and components. Compare with official OpenTelemetry Collector which is primarily designed for mainstream products on the market. There are great potential to support various OpenTelemetry data signals from different sources of whatever any type.
- Propose and promote related [OpenTelemetry semantic conventions](https://opentelemetry.io/docs/concepts/semantic-conventions/) which can greatly improve the usability of OpenTelemetry.
The "SDK" component of this project is the encapsulation of the OpenTelemetry Java SDK which can simplify the development process. The "Data Collector (DC)" component is the receiver implementation which can be used to collect OpenTelemetry data signals (metrics, traces, logs) from various sources. The "Agent" component is the standalone engine to run the Data Collectors. Users can also slightly revise the Agent code to have this functionality built into their own applications or products. The "Agent" component includes a thread pool to run the Data Collectors and a stanbdard otlp exporter to forward the data to the backend. There are several addional components including a built-in batch processor for traces and logs collection, and an optional Prometheus exportor for metrics collection.There are "Templates" in this project which can be used as templates to build your own Date Collectors and Agents for different categories of systems. The Template is an optional component to be simplify the creation of Data Collectors and Agents.
We highly respect the existing official semantic specifications of OpenTelemetry. While we also have some new proposed OpenTelemetry semantic conventions which can be used to standardize the data models.
Note: The project is partially from [ODCD](https://github.com/instana/otel-dc) with [MIT license](https://github.com/instana/otel-dc/blob/main/LICENSE). I am also the creator and the kernel code author of ODCD.
## Receivers provided by OJR besides the SDK
We will provide more receivers in the future and welcome contributions. Right now there are only metrics receivers available, while the OJR SDK itself can also support traces and logs.
| Receiver name | Type | Status | JDK required |
|---------------|------|--------|--------------|
| [Dameng Database](ojr-dameng-db/README.md) | metrics | beta | Java 8+ |
| [Oceanbase Database](ojr-oceanbase-db/README.md) | metrics | alpha | Java 8+ |
| [Informix Database](ojr-informix-db/README.md) | metrics | alpha | Java 8+ |
| [Linux Host](ojr-linux-host/README.md) | metrics | alpha | Java 8+ |
| [SNMP Host](ojr-snmp-host/README.md) | metrics | alpha | Java 11+ |
| [IBM MQ Appliance](ojr-mq-appliance/README.md) | metrics | beta | Java 8+ |## Common Parameters for Receivers
| Parameter | Scope | Description | Default |Examples |
|-----------|-------|-------------|---------|---------|
| otel.poll.interval | instance | The time interval to query metrics in seconds | 25 | 50 |
| otel.callback.interval | instance | The time interval to post data to backend in seconds | 30 | 60 |
| otel.backend.url | instance | The URL of the OTel Backend. | http://127.0.0.1:4318 | http://127.0.0.1:4318 https://my-server:4318 |
| otel.transport | instance | The transport protocol. | http | http grpc prometheus grpc+prometheus http+prometheus |
| otel.service.name | instance | The OTel Service name | OJR | MyDataService |
| otel.service.instance.id | instance | The OTel Service instance ID (optional) | N/A | Instana-01 |
| otel.transport.timeout | instance | The transport timeout in milliseconds (optional) | 10000 | 10000 |
| otel.transport.delay | instance | The transport delay (used for Batch processor) in milliseconds (optional) | 100 | 100 |
| prometheus.port | instance | The port of Prometheus endpoint if prometheus is enabled (optional) | 16543 | 16543 |
| prometheus.host | instance | The host of Prometheus endpoint if prometheus is enabled (optional) | N/A | localhost |