mirror of
https://github.com/CherryHQ/cherry-studio.git
synced 2025-12-19 06:30:10 +08:00
* feat: add tracing modules * Initial commit * fix: problem * fix: update trace web * fix: trace view * fix: trace view * fix: fix some problem * fix: knowledge and mcp trace * feat: save trace to user home dir * feat: open trace with electron browser window * fix: root trace outputs * feat: trace internationalization and add trace icon * feat: add trace title * feat: update * package.json添加windows运行script * feat: update window title * fix: mcp trace param * fix: error show * fix: listTool result * fix: merge error * feat: add stream usage and response * feat: change trace stream * fix: change stream adapter * fix: span detail show problem * fix: process show by time * fix: stream outputs * fix: merge problem * fix: stream outputs * fix: output text * fix: EDAS support text * fix: change trace footer style * fix: topicId is loaded multiple times * fix: span reload problem & attribute with cache * fix: refresh optimization * Change Powered by text. * resolve upstream conflicts * fix: build-time type exception * fix: exceptions not used when building * fix: recend no trace * fix: resend trace list * fix: delete temporary files * feat: trace for resend * fix: trace for resend message with edit * fix: directory structure and construction method of mcp-trace * fix: change CRLF to LF * fix: add function call outputs * Revert "fix: change CRLF to LF" * fix: reorganize multi-model display * fix: append model trace binding topic * fix: some problems * fix: code optimization * fix: delete async * fix: UI optimization * fix: sort import --------- Co-authored-by: 崔顺发 <csf01409784@alibaba-inc.com> Co-authored-by: 管鑫荣 <gxr01409783@alibaba-inc.com>
47 lines
1.8 KiB
TypeScript
47 lines
1.8 KiB
TypeScript
import { trace, Tracer } from '@opentelemetry/api'
|
|
import { AsyncLocalStorageContextManager } from '@opentelemetry/context-async-hooks'
|
|
import { W3CTraceContextPropagator } from '@opentelemetry/core'
|
|
import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http'
|
|
import { BatchSpanProcessor, ConsoleSpanExporter, SpanProcessor } from '@opentelemetry/sdk-trace-base'
|
|
import { NodeTracerProvider } from '@opentelemetry/sdk-trace-node'
|
|
|
|
import { defaultConfig, TraceConfig } from '../trace-core/types/config'
|
|
|
|
export class NodeTracer {
|
|
private static provider: NodeTracerProvider
|
|
private static defaultTracer: Tracer
|
|
private static spanProcessor: SpanProcessor
|
|
|
|
static init(config?: TraceConfig, spanProcessor?: SpanProcessor) {
|
|
if (config) {
|
|
defaultConfig.serviceName = config.serviceName || defaultConfig.serviceName
|
|
defaultConfig.endpoint = config.endpoint || defaultConfig.endpoint
|
|
defaultConfig.headers = config.headers || defaultConfig.headers
|
|
defaultConfig.defaultTracerName = config.defaultTracerName || defaultConfig.defaultTracerName
|
|
}
|
|
this.spanProcessor = spanProcessor || new BatchSpanProcessor(this.getExporter())
|
|
this.provider = new NodeTracerProvider({
|
|
spanProcessors: [this.spanProcessor]
|
|
})
|
|
this.provider.register({
|
|
propagator: new W3CTraceContextPropagator(),
|
|
contextManager: new AsyncLocalStorageContextManager()
|
|
})
|
|
this.defaultTracer = trace.getTracer(config?.defaultTracerName || 'default')
|
|
}
|
|
|
|
private static getExporter(config?: TraceConfig) {
|
|
if (config && config.endpoint) {
|
|
return new OTLPTraceExporter({
|
|
url: `${config.endpoint}/v1/traces`,
|
|
headers: config.headers || undefined
|
|
})
|
|
}
|
|
return new ConsoleSpanExporter()
|
|
}
|
|
|
|
public static getTracer() {
|
|
return this.defaultTracer
|
|
}
|
|
}
|