Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix missing spans in gorillamux instrumentation #86

Merged
merged 27 commits into from
May 12, 2023
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
b2d441b
adjust output for e2e test to remove empty span
JamieDanielson Apr 19, 2023
c1bc4d0
only use one http function in http server instr
JamieDanielson Apr 19, 2023
63ec620
Revert "only use one http function in http server instr"
JamieDanielson Apr 19, 2023
47a47f2
only use one http function - keep refactor
JamieDanielson Apr 19, 2023
f7605a2
keep both func names but only register 1 probe
JamieDanielson Apr 20, 2023
28a5ac1
mirror changes to gorillamux from server #34
JamieDanielson Apr 20, 2023
c843731
no more empty spans for gorillamux
JamieDanielson Apr 20, 2023
853e580
revert http funcname to 1, keep range for register
JamieDanielson Apr 20, 2023
205cfb7
make generate
JamieDanielson Apr 20, 2023
9e30693
Merge branch 'main' into jamie.fix-empty-spans
JamieDanielson Apr 20, 2023
898748d
Merge branch 'main' into jamie.fix-empty-spans
JamieDanielson May 5, 2023
94be05f
fix error logger, merge some main changes
JamieDanielson May 5, 2023
ce13c1d
update changelog
JamieDanielson May 5, 2023
9488556
Merge branch 'main' into jamie.fix-empty-spans
MikeGoldsmith May 9, 2023
2bd277b
Update CHANGELOG.md
JamieDanielson May 9, 2023
806a608
Update CHANGELOG.md
JamieDanielson May 9, 2023
6c651e8
Update pkg/instrumentors/bpf/github.com/gorilla/mux/bpf/probe.bpf.c
JamieDanielson May 9, 2023
5a075a4
set Method size to 7 in gorillamux probe
JamieDanielson May 9, 2023
32cc57b
set Method size to 7 in gin-gonic probe
JamieDanielson May 9, 2023
f8d5608
set Method size to 7 in nethttp probe
JamieDanielson May 9, 2023
186b8f9
Merge branch 'main' into jamie.fix-empty-spans
JamieDanielson May 9, 2023
1ea0e48
updated traces.json after span name pr merged
JamieDanielson May 9, 2023
2c9a556
also set method len to 7 in gorillamux probe c
JamieDanielson May 9, 2023
6ade2a2
also set method len to 7 in gin-gonic probe c
JamieDanielson May 9, 2023
4701f50
also set method len to 7 in nethttp probe c
JamieDanielson May 9, 2023
4f2f16f
make docker-generate
JamieDanielson May 9, 2023
d37fed7
Merge branch 'main' into jamie.fix-empty-spans
MikeGoldsmith May 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http

## [Unreleased]

### Added
JamieDanielson marked this conversation as resolved.
Show resolved Hide resolved

- Fix missing spans in gorillamux instrumentation ([#86](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/86))
JamieDanielson marked this conversation as resolved.
Show resolved Hide resolved

## [v0.2.0-alpha] - 2023-05-03

### Added
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,14 +85,17 @@ int uprobe_GorillaMux_ServeHTTP(struct pt_regs *ctx) {
// Write event
httpReq.sc = generate_span_context();
bpf_map_update_elem(&context_to_http_events, &goroutine, &httpReq, 0);
bpf_map_update_elem(&spans_in_progress, &goroutine, &httpReq.sc, 0);
long res = bpf_map_update_elem(&spans_in_progress, &goroutine, &httpReq.sc, 0);
JamieDanielson marked this conversation as resolved.
Show resolved Hide resolved
return 0;
}

SEC("uprobe/GorillaMux_ServeHTTP")
int uprobe_GorillaMux_ServeHTTP_Returns(struct pt_regs *ctx) {
u64 request_pos = 4;
void *goroutine = get_goroutine_address(ctx, ctx_ptr_pos);
void *httpReq_ptr = bpf_map_lookup_elem(&context_to_http_events, &goroutine);
void* req_ptr = get_argument(ctx, request_pos);

void* httpReq_ptr = bpf_map_lookup_elem(&context_to_http_events, &goroutine);
struct http_request_t httpReq = {};
bpf_probe_read(&httpReq, sizeof(httpReq), httpReq_ptr);
httpReq.end_time = bpf_ktime_get_ns();
Expand Down
50 changes: 30 additions & 20 deletions pkg/instrumentors/bpf/github.com/gorilla/mux/probe.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,15 +44,15 @@ import (
type Event struct {
StartTime uint64
EndTime uint64
Method [100]byte
Method [6]byte
MrAlias marked this conversation as resolved.
Show resolved Hide resolved
Path [100]byte
SpanContext context.EBPFSpanContext
}

// Instrumentor is the gorilla/mux instrumentor.
type Instrumentor struct {
bpfObjects *bpfObjects
uprobe link.Link
uprobes []link.Link
returnProbs []link.Link
eventsReader *perf.Reader
}
Expand Down Expand Up @@ -112,41 +112,51 @@ func (g *Instrumentor) Load(ctx *context.InstrumentorContext) error {
return err
}

offset, err := ctx.TargetDetails.GetFunctionOffset(g.FuncNames()[0])
for _, funcName := range g.FuncNames() {
g.registerProbes(ctx, funcName)
}
rd, err := perf.NewReader(g.bpfObjects.Events, os.Getpagesize())
if err != nil {
return err
}
g.eventsReader = rd

return nil
}

func (g *Instrumentor) registerProbes(ctx *context.InstrumentorContext, funcName string) {
JamieDanielson marked this conversation as resolved.
Show resolved Hide resolved
logger := log.Logger.WithName("gorilla/mux-instrumentor").WithValues("function", funcName)
offset, err := ctx.TargetDetails.GetFunctionOffset(funcName)
if err != nil {
logger.Error(err, "could not find function start offset. Skipping")
return
}
retOffsets, err := ctx.TargetDetails.GetFunctionReturns(funcName)
if err != nil {
logger.Error(err, "could not find function end offset. Skipping")
JamieDanielson marked this conversation as resolved.
Show resolved Hide resolved
return
}

up, err := ctx.Executable.Uprobe("", g.bpfObjects.UprobeGorillaMuxServeHTTP, &link.UprobeOptions{
Address: offset,
})
if err != nil {
return err
logger.Error(err, "could not insert start uprobe. Skipping")
return
}

g.uprobe = up
retOffsets, err := ctx.TargetDetails.GetFunctionReturns(g.FuncNames()[0])
if err != nil {
return err
}
g.uprobes = append(g.uprobes, up)

for _, ret := range retOffsets {
retProbe, err := ctx.Executable.Uprobe("", g.bpfObjects.UprobeGorillaMuxServeHTTP_Returns, &link.UprobeOptions{
Address: ret,
})
if err != nil {
return err
logger.Error(err, "could not insert return uprobe. Skipping")
return
}
g.returnProbs = append(g.returnProbs, retProbe)
}

rd, err := perf.NewReader(g.bpfObjects.Events, os.Getpagesize())
if err != nil {
return err
}
g.eventsReader = rd

return nil
}

// Run runs the events processing loop.
Expand Down Expand Up @@ -208,8 +218,8 @@ func (g *Instrumentor) Close() {
g.eventsReader.Close()
}

if g.uprobe != nil {
g.uprobe.Close()
for _, r := range g.uprobes {
r.Close()
}

for _, r := range g.returnProbs {
Expand Down
29 changes: 29 additions & 0 deletions test/e2e/gorillamux/traces.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,35 @@
]
},
"scopeSpans": [
{
"scope": {
"name": "github.com/gorilla/mux"
},
"spans": [
{
"attributes": [
{
"key": "http.method",
"value": {
"stringValue": "GET"
}
},
{
"key": "http.target",
"value": {
"stringValue": "/users/foo"
}
}
],
"kind": 2,
"name": "/users/foo",
"parentSpanId": "",
"spanId": "xxxxx",
"status": {},
"traceId": "xxxxx"
}
]
},
{
"scope": {
"name": "net/http"
Expand Down