- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
OpenTelemetry 可用于跟踪 React 应用程序的性能问题和错误。您可以跟踪从前端 web 应用程序到下游服务的用户请求。 OpenTelemetry 是云原生计算基金会( CNCF )下的一个开源项目,旨在标准化遥测数据的生成和收集。已成为下一代可观测平台的事实标准.
React (也称为 React.js 或 ReactJS )是一个免费的开源前端 JavaScript 库,用于基于 UI 组件构建用户界面。它是由 Meta (以前的 Facebook )和一个由个人开发者和公司组成的社区维护的。 React 可以作为使用 Next.js 等框架开发单页、移动或服务器渲染应用程序的基础.
然而, React 只关心状态管理和将状态呈现给 DOM ,因此创建 React 应用程序通常需要使用额外的库进行路由,以及某些客户端功能.
使用 opentelemetry-js 库,你可以让你的 React 应用生成跟踪数据。您可以跟踪从前端 web 应用程序到下游服务的用户请求.
在演示如何实现 OpenTelemetry 库之前,让我们简要概述一下 OpenTelmetry .
OpenTelemetry 是一套与第三方厂商无关的开源工具、API 和 SDK,用于检测应用程序,以创建和管理遥测数据(日志、指标和跟踪).
OpenTelemetry 库的 instrument(采集程序) 应用程序代码生成遥测数据,然后发送到可观察性工具进行存储和可视化 。
OpenTelemetry 是建立可观测性框架的基础。它还为您提供了选择后端分析工具的自由.
在本文中,我们将使用 SigNoz 作为后端分析工具。SigNoz 是一个全栈开源 APM 工具,可用于存储和可视化 OpenTelemetry 收集的遥测数据。它是在 OpenTelemetry 上原生构建的,并适用于 OTLP 数据格式.
SigNoz 为最终用户提供了查询和可视化功能,并附带了用于应用程序度量和跟踪的开箱即用图表.
现在,让我们开始了解如何使用 opentelemetry-js 库,然后在 SigNoz 中可视化收集的数据.
DigitalOcean 托管集群( k8s v1.24.13 ).
helm repo add signoz https://charts.signoz.io
helm install signoz signoz/signoz -n apm --create-namespace \
--set otelCollector.config.receivers.otlp.protocols.http.include_metadata=true \
--set otelCollector.config.receivers.otlp.protocols.http.cors.allowed_origins='https://apm-demo.react-admin.com'
注意:cors 跨域设置,我这里 React 应用域名是 https://apm-demo.react-admin.com .
kubectl get po -n apm
NAME READY STATUS RESTARTS AGE
chi-signoz-clickhouse-cluster-0-0-0 1/1 Running 0 3m51s
signoz-alertmanager-0 1/1 Running 0 4m5s
signoz-clickhouse-operator-54b6d79f58-b47ff 2/2 Running 2 (4m2s ago) 4m5s
signoz-frontend-564b8c4868-88grm 1/1 Running 0 4m5s
signoz-k8s-infra-otel-agent-dqh5c 1/1 Running 0 4m6s
signoz-k8s-infra-otel-agent-jdvnh 1/1 Running 0 4m6s
signoz-k8s-infra-otel-agent-tb8sp 1/1 Running 0 4m6s
signoz-k8s-infra-otel-deployment-dc85b496f-n6dhm 1/1 Running 0 4m5s
signoz-otel-collector-655cff46d8-7z5wn 1/1 Running 0 4m5s
signoz-otel-collector-metrics-7775fc9857-mb8wv 1/1 Running 0 4m5s
signoz-query-service-0 1/1 Running 0 4m5s
signoz-zookeeper-0 1/1 Running 0 4m5s
此集群 Ingress Controller 是 Traefik ,配置如下:
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: ingest
namespace: apm
spec:
entryPoints:
- web
routes:
- match: PathPrefix(`/`) && Host(`ingest.doge-data.com`)
kind: Rule
services:
- name: signoz-otel-collector
port: 4318
测试地址:
仓库:
仓库:
官方文档:
位于示例仓库: src/helpers/tracing/index.ts 。
import { context, trace, Span, SpanStatusCode } from "@opentelemetry/api";
import { WebTracerProvider } from "@opentelemetry/sdk-trace-web";
import { Resource } from "@opentelemetry/resources";
import { SimpleSpanProcessor } from "@opentelemetry/sdk-trace-base";
import { OTLPTraceExporter } from "@opentelemetry/exporter-trace-otlp-http";
import { ZoneContextManager } from "@opentelemetry/context-zone";
import { FetchInstrumentation } from "@opentelemetry/instrumentation-fetch";
import { FetchError } from "@opentelemetry/instrumentation-fetch/build/src/types";
import { registerInstrumentations } from "@opentelemetry/instrumentation";
const serviceName = "link-frontend";
const resource = new Resource({ "service.name": serviceName });
const provider = new WebTracerProvider({ resource });
const collector = new OTLPTraceExporter({
url: "https://ingest.doge-data.com/v1/traces",
// headers: {
// "signoz-access-token": "SigNoz-Cloud-Ingestion-Token-HERE"
// }
});
provider.addSpanProcessor(new SimpleSpanProcessor(collector));
provider.register({ contextManager: new ZoneContextManager() });
const webTracerWithZone = provider.getTracer(serviceName);
declare const window: any;
var bindingSpan: Span | undefined;
window.startBindingSpan = (
traceId: string,
spanId: string,
traceFlags: number
) => {
bindingSpan = webTracerWithZone.startSpan("");
bindingSpan.spanContext().traceId = traceId;
bindingSpan.spanContext().spanId = spanId;
bindingSpan.spanContext().traceFlags = traceFlags;
};
registerInstrumentations({
instrumentations: [
new FetchInstrumentation({
propagateTraceHeaderCorsUrls: ["/.*/g"],
clearTimingResources: true,
applyCustomAttributesOnSpan: (
span: Span,
request: Request | RequestInit,
result: Response | FetchError
) => {
const attributes = (span as any).attributes;
if (attributes.component === "fetch") {
span.updateName(
`${attributes["http.method"]} ${attributes["http.url"]}`
);
}
if (result instanceof Error) {
span.setStatus({
code: SpanStatusCode.ERROR,
message: result.message,
});
span.recordException(result.stack || result.name);
}
},
}),
],
});
export function traceSpan<F extends (...args: any) => ReturnType<F>>(
name: string,
func: F
): ReturnType<F> {
var singleSpan: Span;
if (bindingSpan) {
const ctx = trace.setSpan(context.active(), bindingSpan);
singleSpan = webTracerWithZone.startSpan(name, undefined, ctx);
bindingSpan = undefined;
} else {
singleSpan = webTracerWithZone.startSpan(name);
}
return context.with(trace.setSpan(context.active(), singleSpan), () => {
try {
const result = func();
singleSpan.end();
return result;
} catch (error) {
singleSpan.setStatus({ code: SpanStatusCode.ERROR });
singleSpan.end();
throw error;
}
});
}
位于示例仓库: src/components/TracingButton/index.tsx 。
import { Button } from '@mui/material'
import { traceSpan } from 'helpers/tracing'
interface Props {
label: string;
id?: string;
secondary?: boolean;
onClick: () => void;
}
export default (props: Props) => {
const onClick = (): void =>
traceSpan(`'${props.label}' button clicked`, props.onClick);
return (
<div>
<Button
id={props.id}
variant={"contained"}
color={props.secondary ? "secondary" : "primary"}
onClick={onClick}
>
{props.label}
</Button>
</div>
);
};
转到 https://apm-demo.react-admin.com , 单击 FETCH LINKS .
本篇文章侧重于快速实践, OpenTelemetry 本身很复杂,涉及很多 基础概念 ,大家自行翻阅文档.
SigNoz 作为后端分析与可视化工具。虽相对于 ELK Stack 还有很多不足,但它号称是基于 OpenTelemetry 生态原生构建的下一代开源可观测平台,期待它后续发展.
有兴趣的朋友,也可以二次开发 SigNoz,增加自身项目需求。目前也还比较容易的.
最后此篇关于React前端应用中快速实践OpenTelemetry云原生可观测性(SigNoz/K8S)的文章就讲到这里了,如果你想了解更多关于React前端应用中快速实践OpenTelemetry云原生可观测性(SigNoz/K8S)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在尝试使 OpenTelemetry 导出器与 OpenTelemetry 收集器一起使用。 我找到了 OpenTelemetry collector demo . 所以我复制了这四个配置文件 d
随着 Opentelemetry 成为跟踪的新标准,并且它与供应商无关,那么我们如何为 opentelemetry 选择后端供应商? 例如,目前有很多厂商支持 Opentelemetry,如 GCP
我有一个使用 OpenTelemetry 的 C# 应用程序。 不同的后端收集器(如 Jaeger)有不同的导出器 但在我的开发环境中,并没有设置这样的后端服务。 虽然我可以使用控制台导出器,但它会与
我有一个使用 OpenTelemetry 的 C# 应用程序。 不同的后端收集器(如 Jaeger)有不同的导出器 但在我的开发环境中,并没有设置这样的后端服务。 虽然我可以使用控制台导出器,但它会与
我很困惑为什么 OpenTelemetry documentaion具有 OpenTelemetry Python API 和 OpenTelemetry Python SDK。 就像在 python
我是 OpenTelemetry 词的新手。我已经分别为我的服务创建了跨度,但是当我尝试使用上下文传播来组合两个不同服务的跨度时,我无法成功地做到这一点。我使用了以下代码: // at client
我正在尝试让 OpenTelemetry 跟踪与 FastAPI 和请求一起使用。目前,我的设置如下所示: import requests from opentelemetry.baggage.pro
随着 OpenTelemetry 试图成为应用程序/服务可观察性的事实上的标准,Micrometer 在哪里适合? Micrometer 网站声称它是用于度量标准的 SLF4J,但它是否与 OpenT
背景 我正在尝试在前端应用程序中进行跟踪。 我无法使用 @opentelemetry/exporter-jaeger自 I believe it is for Node.js back end app
我正在尝试使用 opentelemetry 和 open telemetry-otlp 通过 OTLP 向 Honeycomb 提供可观察性数据。 我正在使用类似这样的东西作为概念证明(如果你想运行它
我正在尝试使用 opentelemetry 和 open telemetry-otlp 通过 OTLP 向 Honeycomb 提供可观察性数据。 我正在使用类似这样的东西作为概念证明(如果你想运行它
我有 krakend apigateway,它使用 opentracing 并将请求 header 作为 X-B3-... 发送以进行跟踪,我的服务使用 opentelemetry。 这就是我现在在
我知道我们要使用上下文传播来获取创建为彼此子项的父 traceid 和跨度,但我的发布者使用的是 header (nats 而不是 http) 我的消息代理使用 header ,我在出站请求中将 tr
我正在尝试在我的 Angular 应用程序中集成 Opentelemetry (Otl) 来跟踪前端调用。一切正常,我可以在 Zipkin 中看到调用。 但唯一的问题是它在 Zipkin 界面中显示为
我在学习tracing和 open-telemetry在 rust 中。我觉得有太多的概念和太多的 crate (至少在 Rust 中)看不到痕迹。 我写了一个简单的 lib 应用程序,它添加了两个
我有一个用 .net 6 编写的项目。我使用 Azure Function 将数据发送到服务总线和 MediatR。如何将开放遥测添加到我的 Azure 函数? [Function("EBcktErr
我尝试使用配置 yaml 文件作为参数来运行 opentelemetry docker 镜像: docker run -v "./otel-collector-config.yaml":/otel-c
我正在学习 OpenTelemetry,我想知道 dotnet-monitor 如何与 OpenTelemetry (Meter) 连接。这些东西是否以某种方式连接,或者 dotnet-monitor
我正在按照 this guide 将 opentelemetry 跟踪发送到 Azure Monitor(通过 Application Insights) . Application Insights
我正在按照 this guide 将 opentelemetry 跟踪发送到 Azure Monitor(通过 Application Insights) . Application Insights
我是一名优秀的程序员,十分优秀!