GO2Sky is an instrument SDK library, written in Go, by following Apache SkyWalking tracing and metrics formats.
NOTE: This repo provided by DaoCloud Labs, and used for DaoCloud DMP only.
protocol refs reporter/grpc dir and https://gitlab.daocloud.io/microservice/dmp/skywalking/skywalking-data-collect-protocol.git.
$ go get -u github.com/DaoCloud-Labs/go2sky
The API of this project is still evolving. The use of vendoring tool is recommended.
By completing this quickstart, you will learn how to trace local methods. For more details, please view the example
GO2Sky can export traces to Apache SkyWalking OAP server or local logger. In the following example, we configure GO2Sky to export to OAP server,
which is listening on oap-skywalking port 11800, and all of the spans from this program will be associated with a service name example and within test-env env.
r, err := reporter.NewGRPCReporter("oap-skywalking:11800")
if err != nil {
log.Fatalf("new reporter error %v \n", err)
}
defer r.Close()
tracer, err := go2sky.NewTracer("test-env", "example", go2sky.WithReporter(r))To create a span in a trace, we used the Tracer to start a new span. We indicate this as the root span because of
passing context.Background(). We must also be sure to end this span, which will be show in End span.
span, ctx, err := tracer.CreateLocalSpan(context.Background())Get the TraceID of the activeSpan in the Context.
go2sky.TraceID(ctx)A sub span created as the children of root span links to its parent with Context.
subSpan, newCtx, err := tracer.CreateLocalSpan(ctx)We must end the spans so they becomes available for sending to the backend by a reporter.
subSpan.End()
span.End()We cover some advanced topics about GO2Sky.
Trace links spans belong to it by using context propagation which varies between different scenario.
We use context package to link spans. The root span usually pick context.Background(), and sub spans
will inject the context generated by its parent.
//Create a new context
entrySpan, entryCtx, err := h.tracer.CreateEntrySpan(context.Background(), ...)
// Some operation
...
// Link two spans by injecting entrySpan context into exitSpan
exitSpan, err := t.tracer.CreateExitSpan(entryCtx, ...)We use Entry span to extract context from downstream service, and use Exit span to inject context to
upstream service.
Entry and Exit spans make sense to OAP analysis which generates topology map and service metrics.
//Extract context from HTTP request header `sw6`
span, ctx, err := h.tracer.CreateEntrySpan(r.Context(), "/api/login", func() (string, error) {
return r.Header.Get("sw6"), nil
})
// Some operation
...
// Inject context into HTTP request header `sw6`
span, err := t.tracer.CreateExitSpan(req.Context(), "/service/validate", "tomcat-service:8080", func(header string) error {
req.Header.Set(propagation.Header, header)
return nil
})We set tags into a span which is stored in the backend, but some tags have special purpose. OAP server may use them to aggregate metrics, generate topology map and etc.
They are defined as constant in root package with prefix Tag.
Plugins is integrated with specific framework, for instance, net/http, gin and etc. They
are stored in plugins package.
Apache License 2.0. See LICENSE file for details.