| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- package logs
- import (
- "context"
- "time"
- otel "github.com/agoda-com/opentelemetry-logs-go"
- "github.com/agoda-com/opentelemetry-logs-go/exporters/otlp/otlplogs"
- "github.com/agoda-com/opentelemetry-logs-go/exporters/otlp/otlplogs/otlplogshttp"
- otelLogs "github.com/agoda-com/opentelemetry-logs-go/logs"
- sdk "github.com/agoda-com/opentelemetry-logs-go/sdk/logs"
- "github.com/coroot/coroot-node-agent/common"
- "github.com/coroot/coroot-node-agent/flags"
- "github.com/coroot/logparser"
- klog "github.com/sirupsen/logrus"
- "go.opentelemetry.io/otel/attribute"
- "go.opentelemetry.io/otel/sdk/resource"
- semconv "go.opentelemetry.io/otel/semconv/v1.18.0"
- )
- var otelLogger otelLogs.Logger
- func Init(machineId, hostname, version string) {
- endpointUrl := *flags.LogsEndpoint
- if endpointUrl == nil {
- klog.Infoln("no OpenTelemetry logs collector endpoint configured")
- return
- }
- klog.Infoln("OpenTelemetry logs collector endpoint:", endpointUrl.String())
- path := endpointUrl.Path
- if path == "" {
- path = "/"
- }
- opts := []otlplogshttp.Option{
- otlplogshttp.WithEndpoint(endpointUrl.Host),
- otlplogshttp.WithURLPath(path),
- otlplogshttp.WithHeaders(common.AuthHeaders()),
- }
- if endpointUrl.Scheme != "https" {
- opts = append(opts, otlplogshttp.WithInsecure())
- }
- client := otlplogshttp.NewClient(opts...)
- exporter, _ := otlplogs.NewExporter(context.Background(), otlplogs.WithClient(client))
- loggerProvider := sdk.NewLoggerProvider(
- sdk.WithBatcher(exporter),
- sdk.WithResource(
- resource.NewWithAttributes(
- semconv.SchemaURL,
- semconv.ServiceName("coroot-node-agent"),
- semconv.HostName(hostname),
- semconv.HostID(machineId),
- ),
- ),
- )
- otel.SetLoggerProvider(loggerProvider)
- otelLogger = loggerProvider.Logger("coroot-node-agent", otelLogs.WithInstrumentationVersion(version))
- }
- func OtelLogEmitter(containerId string) logparser.OnMsgCallbackF {
- if otelLogger == nil {
- return nil
- }
- return func(ts time.Time, level logparser.Level, patternHash string, msg string) {
- severityText := level.String()
- severityNumber := otelLogs.UNSPECIFIED
- switch level {
- case logparser.LevelCritical:
- severityNumber = otelLogs.FATAL
- case logparser.LevelError:
- severityNumber = otelLogs.ERROR
- case logparser.LevelWarning:
- severityNumber = otelLogs.WARN
- case logparser.LevelInfo:
- severityNumber = otelLogs.INFO
- case logparser.LevelDebug:
- severityNumber = otelLogs.DEBUG
- }
- otelLogger.Emit(
- otelLogs.NewLogRecord(otelLogs.LogRecordConfig{
- ObservedTimestamp: ts,
- SeverityText: &severityText,
- SeverityNumber: &severityNumber,
- Body: &msg,
- Resource: resource.NewSchemaless(
- semconv.ServiceName(common.ContainerIdToOtelServiceName(containerId)),
- semconv.ContainerID(containerId),
- ),
- Attributes: &[]attribute.KeyValue{
- attribute.Key("pattern.hash").String(patternHash),
- },
- }),
- )
- }
- }
|