forked from apache/eventmesh
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' of https://github.com/slowpao/incubator-eventmesh…
… into fix-3323 � Conflicts: � eventmesh-connector-plugin/eventmesh-connector-pulsar/src/main/java/org/apache/eventmesh/connector/pulsar/consumer/PulsarConsumerImpl.java
- Loading branch information
Showing
506 changed files
with
6,320 additions
and
6,041 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
# 分布式追踪 | ||
|
||
## OpenTelemetry概述 | ||
|
||
OpenTelemetry是一组API和SDK的工具,您可以使用它来仪器化、生成、收集和导出遥测数据(指标、日志和追踪),以便进行分析,以了解您的软件性能和行为。 | ||
|
||
## 需求 | ||
|
||
- 设置追踪器 | ||
- 不同的导出器 | ||
- 在服务器中开始和结束跨度 | ||
|
||
## 设计细节 | ||
|
||
- 跨度处理器:BatchSpanProcessor | ||
|
||
- 导出器:默认为日志,可以从属性中更改 | ||
|
||
```java | ||
// Configure the batch spans processor. This span processor exports span in batches. | ||
BatchSpanProcessor batchSpansProcessor = | ||
BatchSpanProcessor.builder(exporter) | ||
.setMaxExportBatchSize(512) // set the maximum batch size to use | ||
.setMaxQueueSize(2048) // set the queue size. This must be >= the export batch size | ||
.setExporterTimeout( | ||
30, TimeUnit.SECONDS) // set the max amount of time an export can run before getting | ||
// interrupted | ||
.setScheduleDelay(5, TimeUnit.SECONDS) // set time between two different exports | ||
.build(); | ||
OpenTelemetrySdk.builder() | ||
.setTracerProvider( | ||
SdkTracerProvider.builder().addSpanProcessor(batchSpansProcessor).build()) | ||
.build(); | ||
``` | ||
|
||
1. 当使用`EventMeshHTTPServer`类的`init()`方法时,类`AbstractHTTPServer`将获取跟踪器。 | ||
|
||
```java | ||
super.openTelemetryTraceFactory = new OpenTelemetryTraceFactory(eventMeshHttpConfiguration); | ||
super.tracer = openTelemetryTraceFactory.getTracer(this.getClass().toString()); | ||
super.textMapPropagator = openTelemetryTraceFactory.getTextMapPropagator(); | ||
``` | ||
|
||
2. 然后,在类`AbstractHTTPServer`中的跟踪将起作用。 | ||
|
||
## 问题 | ||
|
||
### 如何在类“OpenTelemetryTraceFactory”中设置不同的导出器?(已解决) | ||
|
||
在从属性中获取导出器类型之后,如何处理它。 | ||
|
||
`logExporter`只需要创建新实例即可。 | ||
|
||
但是,“zipkinExporter”需要新建并使用“getZipkinExporter()”方法。 | ||
|
||
## 解决方案 | ||
|
||
### 不同导出器的解决方案 | ||
|
||
使用反射获取导出器。 | ||
|
||
首先,不同的导出器必须实现接口“EventMeshExporter”。 | ||
|
||
然后,我们从配置中获取导出器名称,并反射到该类。 | ||
|
||
```java | ||
//different spanExporter | ||
String exporterName = configuration.eventMeshTraceExporterType; | ||
//use reflection to get spanExporter | ||
String className = String.format("org.apache.eventmesh.runtime.exporter.%sExporter",exporterName); | ||
EventMeshExporter eventMeshExporter = (EventMeshExporter) Class.forName(className).newInstance(); | ||
spanExporter = eventMeshExporter.getSpanExporter(configuration); | ||
``` | ||
|
||
另外,这将包含try catch。如果无法成功获取指定的导出器,则将使用默认的日志导出器。 | ||
|
||
#### 不同导出器的改进 | ||
|
||
SPI(待完成) | ||
|
||
## 附录 | ||
|
||
### 参考资料 | ||
|
||
- <https://github.com/open-telemetry/docs-cn/blob/main/QUICKSTART.md> | ||
|
||
- <https://github.com/open-telemetry/opentelemetry-java-instrumentation/tree/main/instrumentation/netty> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -29,6 +29,7 @@ | |
*/ | ||
@Data | ||
public class ConvertInfo { | ||
|
||
char hump; | ||
String key; | ||
Field field; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -28,4 +28,5 @@ | |
* </ul> | ||
*/ | ||
public interface ProtocolTransportObject extends Serializable { | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.