72 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package trace
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/google/uuid"
 | |
| 	"github.com/micro/go-micro/util/ring"
 | |
| )
 | |
| 
 | |
| type trace struct {
 | |
| 	opts Options
 | |
| 
 | |
| 	// ring buffer of traces
 | |
| 	buffer *ring.Buffer
 | |
| }
 | |
| 
 | |
| func (t *trace) Read(opts ...ReadOption) ([]*Span, error) {
 | |
| 	return []*Span{}, nil
 | |
| }
 | |
| 
 | |
| func (t *trace) Start(ctx context.Context, name string) *Span {
 | |
| 	span := &Span{
 | |
| 		Name:     name,
 | |
| 		Trace:    uuid.New().String(),
 | |
| 		Id:       uuid.New().String(),
 | |
| 		Started:  time.Now(),
 | |
| 		Metadata: make(map[string]string),
 | |
| 	}
 | |
| 
 | |
| 	// return span if no context
 | |
| 	if ctx == nil {
 | |
| 		return span
 | |
| 	}
 | |
| 
 | |
| 	s, ok := FromContext(ctx)
 | |
| 	if !ok {
 | |
| 		return span
 | |
| 	}
 | |
| 
 | |
| 	// set trace id
 | |
| 	span.Trace = s.Trace
 | |
| 	// set parent
 | |
| 	span.Parent = s.Id
 | |
| 
 | |
| 	// return the sapn
 | |
| 	return span
 | |
| }
 | |
| 
 | |
| func (t *trace) Finish(s *Span) error {
 | |
| 	// set finished time
 | |
| 	s.Finished = time.Now()
 | |
| 
 | |
| 	// save the span
 | |
| 	t.buffer.Put(s)
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func NewTrace(opts ...Option) Trace {
 | |
| 	var options Options
 | |
| 	for _, o := range opts {
 | |
| 		o(&options)
 | |
| 	}
 | |
| 
 | |
| 	return &trace{
 | |
| 		opts: options,
 | |
| 		// the last 64 requests
 | |
| 		buffer: ring.New(64),
 | |
| 	}
 | |
| }
 |