mirror of
https://github.com/Luzifer/nginx-sso.git
synced 2025-01-07 21:41:49 +00:00
78 lines
2.1 KiB
Go
78 lines
2.1 KiB
Go
|
// Copyright 2018, OpenCensus Authors
|
||
|
//
|
||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
// you may not use this file except in compliance with the License.
|
||
|
// You may obtain a copy of the License at
|
||
|
//
|
||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||
|
//
|
||
|
// Unless required by applicable law or agreed to in writing, software
|
||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
// See the License for the specific language governing permissions and
|
||
|
// limitations under the License.
|
||
|
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"log"
|
||
|
"time"
|
||
|
|
||
|
openzipkin "github.com/openzipkin/zipkin-go"
|
||
|
"github.com/openzipkin/zipkin-go/reporter/http"
|
||
|
"go.opencensus.io/exporter/zipkin"
|
||
|
"go.opencensus.io/trace"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
// The localEndpoint stores the name and address of the local service
|
||
|
localEndpoint, err := openzipkin.NewEndpoint("example-server", "192.168.1.5:5454")
|
||
|
if err != nil {
|
||
|
log.Println(err)
|
||
|
}
|
||
|
|
||
|
// The Zipkin reporter takes collected spans from the app and reports them to the backend
|
||
|
// http://localhost:9411/api/v2/spans is the default for the Zipkin Span v2
|
||
|
reporter := http.NewReporter("http://localhost:9411/api/v2/spans")
|
||
|
defer reporter.Close()
|
||
|
|
||
|
// The OpenCensus exporter wraps the Zipkin reporter
|
||
|
exporter := zipkin.NewExporter(reporter, localEndpoint)
|
||
|
trace.RegisterExporter(exporter)
|
||
|
|
||
|
// For example purposes, sample every trace. In a production application, you should
|
||
|
// configure this to a trace.ProbabilitySampler set at the desired
|
||
|
// probability.
|
||
|
trace.ApplyConfig(trace.Config{DefaultSampler: trace.AlwaysSample()})
|
||
|
|
||
|
ctx := context.Background()
|
||
|
foo(ctx)
|
||
|
}
|
||
|
|
||
|
func foo(ctx context.Context) {
|
||
|
// Name the current span "/foo"
|
||
|
ctx, span := trace.StartSpan(ctx, "/foo")
|
||
|
defer span.End()
|
||
|
|
||
|
// Foo calls bar and baz
|
||
|
bar(ctx)
|
||
|
baz(ctx)
|
||
|
}
|
||
|
|
||
|
func bar(ctx context.Context) {
|
||
|
ctx, span := trace.StartSpan(ctx, "/bar")
|
||
|
defer span.End()
|
||
|
|
||
|
// Do bar
|
||
|
time.Sleep(2 * time.Millisecond)
|
||
|
}
|
||
|
|
||
|
func baz(ctx context.Context) {
|
||
|
ctx, span := trace.StartSpan(ctx, "/baz")
|
||
|
defer span.End()
|
||
|
|
||
|
// Do baz
|
||
|
time.Sleep(4 * time.Millisecond)
|
||
|
}
|