From 88144bbb876ab244ae542efa4a7ed93f632ab550 Mon Sep 17 00:00:00 2001 From: Ron Federman Date: Wed, 16 Aug 2023 22:35:09 +0300 Subject: [PATCH 1/7] Fix offset tracker to build binaries for go stdlib as well --- offsets-tracker/downloader/go_wrapper.go | 23 +++++++++++++------ .../downloader/wrapper/go.modstd.txt | 3 +++ offsets-tracker/main.go | 22 ++++++++++++++---- offsets-tracker/target/target.go | 6 +++-- pkg/inject/offset_results.json | 12 +++++----- 5 files changed, 47 insertions(+), 19 deletions(-) create mode 100644 offsets-tracker/downloader/wrapper/go.modstd.txt diff --git a/offsets-tracker/downloader/go_wrapper.go b/offsets-tracker/downloader/go_wrapper.go index 10540ef11..7449ee8f5 100644 --- a/offsets-tracker/downloader/go_wrapper.go +++ b/offsets-tracker/downloader/go_wrapper.go @@ -18,7 +18,7 @@ import ( _ "embed" "fmt" "io/fs" - "io/ioutil" + "os" "path" "go.opentelemetry.io/auto/offsets-tracker/utils" @@ -30,25 +30,34 @@ var ( //go:embed wrapper/go.mod.txt goMod string + //go:embed wrapper/go.modstd.txt + goModStdLib string + //go:embed wrapper/main.go.txt goMain string ) // DownloadBinary downloads the module with modName at version. -func DownloadBinary(modName string, version string) (string, string, error) { - dir, err := ioutil.TempDir("", appName) +func DownloadBinary(modName string, version string, isGoStandartLib bool) (string, string, error) { + dir, err := os.MkdirTemp("", appName) if err != nil { return "", "", err } - goModContent := fmt.Sprintf(goMod, modName, version) - err = ioutil.WriteFile(path.Join(dir, "go.mod"), []byte(goModContent), fs.ModePerm) + var goModContent string + if isGoStandartLib { + goModContent = fmt.Sprintf(goModStdLib, version) + } else { + goModContent = fmt.Sprintf(goMod, modName, version) + } + + err = os.WriteFile(path.Join(dir, "go.mod"), []byte(goModContent), fs.ModePerm) if err != nil { return "", "", err } goMainContent := fmt.Sprintf(goMain, modName) - err = ioutil.WriteFile(path.Join(dir, "main.go"), []byte(goMainContent), fs.ModePerm) + err = os.WriteFile(path.Join(dir, "main.go"), []byte(goMainContent), fs.ModePerm) if err != nil { return "", "", err } @@ -58,7 +67,7 @@ func DownloadBinary(modName string, version string) (string, string, error) { return "", "", err } - _, _, err = utils.RunCommand("GOOS=linux GOARCH=amd64 go build", dir) + _, _, err = utils.RunCommand(fmt.Sprintf("GOOS=linux GOARCH=amd64 go build -o %s", appName), dir) if err != nil { return "", "", err } diff --git a/offsets-tracker/downloader/wrapper/go.modstd.txt b/offsets-tracker/downloader/wrapper/go.modstd.txt new file mode 100644 index 000000000..4e0829122 --- /dev/null +++ b/offsets-tracker/downloader/wrapper/go.modstd.txt @@ -0,0 +1,3 @@ +module testapp + +go %s \ No newline at end of file diff --git a/offsets-tracker/main.go b/offsets-tracker/main.go index 7c850a6cc..690fa6c6c 100644 --- a/offsets-tracker/main.go +++ b/offsets-tracker/main.go @@ -44,15 +44,22 @@ func main() { log.Fatalf("error in parsing version constraint: %v\n", err) } - stdLibOffsets, err := target.New("go", *outputFile). + stdLibRuntimeOffsets, err := target.New("runtime", *outputFile, true). FindVersionsBy(target.GoDevFileVersionsStrategy). - DownloadBinaryBy(target.DownloadPreCompiledBinaryFetchStrategy). + DownloadBinaryBy(target.WrapAsGoAppBinaryFetchStrategy). VersionConstraint(&minimunGoVersion). FindOffsets([]*binary.DataMember{ { StructName: "runtime.g", Field: "goid", }, + }) + + stdLibNetHttpOffsets, err := target.New("net/http", *outputFile, true). + FindVersionsBy(target.GoDevFileVersionsStrategy). + DownloadBinaryBy(target.WrapAsGoAppBinaryFetchStrategy). + VersionConstraint(&minimunGoVersion). + FindOffsets([]*binary.DataMember{ { StructName: "net/http.Request", Field: "Method", @@ -73,6 +80,13 @@ func main() { StructName: "net/http.Request", Field: "ctx", }, + }) + + stdLibNetUrlOffsets, err := target.New("net/url", *outputFile, true). + FindVersionsBy(target.GoDevFileVersionsStrategy). + DownloadBinaryBy(target.WrapAsGoAppBinaryFetchStrategy). + VersionConstraint(&minimunGoVersion). + FindOffsets([]*binary.DataMember{ { StructName: "net/url.URL", Field: "Path", @@ -83,7 +97,7 @@ func main() { log.Fatalf("error while fetching offsets: %v\n", err) } - grpcOffsets, err := target.New("google.golang.org/grpc", *outputFile). + grpcOffsets, err := target.New("google.golang.org/grpc", *outputFile, false). FindOffsets([]*binary.DataMember{ { StructName: "google.golang.org/grpc/internal/transport.Stream", @@ -128,7 +142,7 @@ func main() { } fmt.Println("Done collecting offsets, writing results to file ...") - err = writer.WriteResults(*outputFile, stdLibOffsets, grpcOffsets) + err = writer.WriteResults(*outputFile, stdLibRuntimeOffsets, stdLibNetHttpOffsets, stdLibNetUrlOffsets, grpcOffsets) if err != nil { log.Fatalf("error while writing results to file: %v\n", err) } diff --git a/offsets-tracker/target/target.go b/offsets-tracker/target/target.go index 9a8a692f8..08075e197 100644 --- a/offsets-tracker/target/target.go +++ b/offsets-tracker/target/target.go @@ -57,6 +57,7 @@ type VersionedResult struct { // Data represents the target Go module data. type Data struct { name string + isGoStdlib bool versionsStrategy VersionsStrategy binaryFetchStrategy BinaryFetchStrategy versionConstraint *version.Constraints @@ -64,12 +65,13 @@ type Data struct { } // New returns a new Data. -func New(name string, fileName string) *Data { +func New(name string, fileName string, isStdlib bool) *Data { return &Data{ name: name, versionsStrategy: GoListVersionsStrategy, binaryFetchStrategy: WrapAsGoAppBinaryFetchStrategy, cache: cache.NewCache(fileName), + isGoStdlib: isStdlib, } } @@ -197,7 +199,7 @@ func (t *Data) findVersions() ([]string, error) { func (t *Data) downloadBinary(modName string, version string) (string, string, error) { switch t.binaryFetchStrategy { case WrapAsGoAppBinaryFetchStrategy: - return downloader.DownloadBinary(modName, version) + return downloader.DownloadBinary(modName, version, t.isGoStdlib) case DownloadPreCompiledBinaryFetchStrategy: return downloader.DownloadBinaryFromRemote(modName, version) } diff --git a/pkg/inject/offset_results.json b/pkg/inject/offset_results.json index 0ef0b42b0..d19414df0 100755 --- a/pkg/inject/offset_results.json +++ b/pkg/inject/offset_results.json @@ -168,7 +168,7 @@ "Header": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { @@ -180,7 +180,7 @@ "Method": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { @@ -192,7 +192,7 @@ "RemoteAddr": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { @@ -204,7 +204,7 @@ "URL": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { @@ -216,7 +216,7 @@ "ctx": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { @@ -244,7 +244,7 @@ "goid": { "versions": { "oldest": "1.12.0", - "newest": "1.20.7" + "newest": "1.21.0" }, "offsets": [ { From d5dd29189dab392d8a8bf5a68bd0d86bb83b672f Mon Sep 17 00:00:00 2001 From: Eden Federman Date: Thu, 17 Aug 2023 07:18:06 -0700 Subject: [PATCH 2/7] Update README.md --- offsets-tracker/README.md | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/offsets-tracker/README.md b/offsets-tracker/README.md index 4c3465147..13c6e9906 100644 --- a/offsets-tracker/README.md +++ b/offsets-tracker/README.md @@ -57,10 +57,10 @@ For example, here is the tracking of `method` field inside `transport.Stream` st ## Versions Discovery -By default, offsets-tracker finds availble versions by executing `go list -versions `. +By default, offsets-tracker finds available versions by executing `go list -versions `. Unfortunately, Go standard library versions are not discoverable via `go list`. -In order to discover Go versions, offsets-tracker can fetch the versions published at `https://go.dev/dl`. +In order to discover Go versions, the offsets-tracker fetch the versions published at `https://go.dev/dl`. Fetching `go.dev` for discovering versions can be enabled by setting`.FindVersionsBy(target.GoDevFileVersionsStrategy)` when registering a new target. ## Download Strategy @@ -68,7 +68,12 @@ Fetching `go.dev` for discovering versions can be enabled by setting`.FindVersio offsets-tracker wraps every Go module version as a Go application that depends on that module. Those applications are the result of [generating template files](./downloader/wrapper) with the appropriate version. -In the case of the Go standard library, offsets-tracker downloads the published binary for the specified version. +In the case of the Go standard library, the offsets-tracker creates a dummy application that depends on the specific library. For example +```go +import ( + _ "net/http" +) +``` ## Version Constraints From 02d066b8a315dc98ed0401fab8b7f173daa1cb09 Mon Sep 17 00:00:00 2001 From: Ron Federman Date: Thu, 17 Aug 2023 18:01:05 +0300 Subject: [PATCH 3/7] Update make docker-offsets, changelog and lint --- CHANGELOG.md | 1 + Makefile | 2 +- offsets-tracker/downloader/go_wrapper.go | 1 + offsets-tracker/main.go | 16 ++++++++++++---- 4 files changed, 15 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 553949090..a71be12a7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -27,6 +27,7 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http - Update generated offsets. ([#186](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/186)) - Reduce Docker image size by using different base image. ([#182](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/182)) - Support for multiple processes in BPF FS. ([#211](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/211)) +- Fix offset tracker to build binaries for go stdlib as well ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) ## [v0.2.1-alpha] - 2023-05-15 diff --git a/Makefile b/Makefile index ed058af7b..ae0469c79 100644 --- a/Makefile +++ b/Makefile @@ -87,7 +87,7 @@ offsets: .PHONY: docker-offsets docker-offsets: - docker run --rm -v $(shell pwd):/app golang:1.20 /bin/sh -c "cd ../app && make offsets" + docker run --rm -v $(shell pwd):/app golang:1.21 /bin/sh -c "cd ../app && make offsets" .PHONY: update-licenses update-licenses: generate $(GOLICENSES) diff --git a/offsets-tracker/downloader/go_wrapper.go b/offsets-tracker/downloader/go_wrapper.go index 7449ee8f5..d6c7e0023 100644 --- a/offsets-tracker/downloader/go_wrapper.go +++ b/offsets-tracker/downloader/go_wrapper.go @@ -38,6 +38,7 @@ var ( ) // DownloadBinary downloads the module with modName at version. +// revive:disable-next-line:flag-parameter func DownloadBinary(modName string, version string, isGoStandartLib bool) (string, string, error) { dir, err := os.MkdirTemp("", appName) if err != nil { diff --git a/offsets-tracker/main.go b/offsets-tracker/main.go index 690fa6c6c..7ab97828b 100644 --- a/offsets-tracker/main.go +++ b/offsets-tracker/main.go @@ -55,7 +55,11 @@ func main() { }, }) - stdLibNetHttpOffsets, err := target.New("net/http", *outputFile, true). + if err != nil { + log.Fatalf("error while fetching offsets for \"runtime\": %v\n", err) + } + + stdLibNetHTTPOffsets, err := target.New("net/http", *outputFile, true). FindVersionsBy(target.GoDevFileVersionsStrategy). DownloadBinaryBy(target.WrapAsGoAppBinaryFetchStrategy). VersionConstraint(&minimunGoVersion). @@ -82,7 +86,11 @@ func main() { }, }) - stdLibNetUrlOffsets, err := target.New("net/url", *outputFile, true). + if err != nil { + log.Fatalf("error while fetching offsets for \"net/http\": %v\n", err) + } + + stdLibNetURLOffsets, err := target.New("net/url", *outputFile, true). FindVersionsBy(target.GoDevFileVersionsStrategy). DownloadBinaryBy(target.WrapAsGoAppBinaryFetchStrategy). VersionConstraint(&minimunGoVersion). @@ -94,7 +102,7 @@ func main() { }) if err != nil { - log.Fatalf("error while fetching offsets: %v\n", err) + log.Fatalf("error while fetching offsets for \"net/url\": %v\n", err) } grpcOffsets, err := target.New("google.golang.org/grpc", *outputFile, false). @@ -142,7 +150,7 @@ func main() { } fmt.Println("Done collecting offsets, writing results to file ...") - err = writer.WriteResults(*outputFile, stdLibRuntimeOffsets, stdLibNetHttpOffsets, stdLibNetUrlOffsets, grpcOffsets) + err = writer.WriteResults(*outputFile, stdLibRuntimeOffsets, stdLibNetHTTPOffsets, stdLibNetURLOffsets, grpcOffsets) if err != nil { log.Fatalf("error while writing results to file: %v\n", err) } From 91c0e3018c3a4aeb0e08ee6076455994830d512c Mon Sep 17 00:00:00 2001 From: Ron Federman <73110295+RonFed@users.noreply.github.com> Date: Fri, 18 Aug 2023 10:49:04 +0300 Subject: [PATCH 4/7] Update offsets-tracker/README.md Co-authored-by: Tyler Yahn --- offsets-tracker/README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/offsets-tracker/README.md b/offsets-tracker/README.md index 13c6e9906..432fdca49 100644 --- a/offsets-tracker/README.md +++ b/offsets-tracker/README.md @@ -69,6 +69,7 @@ offsets-tracker wraps every Go module version as a Go application that depends o Those applications are the result of [generating template files](./downloader/wrapper) with the appropriate version. In the case of the Go standard library, the offsets-tracker creates a dummy application that depends on the specific library. For example + ```go import ( _ "net/http" From 3faba8a439ef7fb5ad4baf80443f7dba4c3dfee1 Mon Sep 17 00:00:00 2001 From: Ron Federman Date: Fri, 18 Aug 2023 11:02:24 +0300 Subject: [PATCH 5/7] Update changelog --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a71be12a7..09623ba09 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -27,7 +27,7 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http - Update generated offsets. ([#186](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/186)) - Reduce Docker image size by using different base image. ([#182](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/182)) - Support for multiple processes in BPF FS. ([#211](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/211)) -- Fix offset tracker to build binaries for go stdlib as well ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) +- Fix offset tracker to build binaries for go stdlib as well. DownloadBinary() now has an additional flag indicating whether it'll build a dummy app for go stdlib or not - this will cause a different go.mod file to be used. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) ## [v0.2.1-alpha] - 2023-05-15 From 7df1db2add968cb06b8de9658ff6b00a47f97613 Mon Sep 17 00:00:00 2001 From: Ron Federman <73110295+RonFed@users.noreply.github.com> Date: Fri, 18 Aug 2023 16:55:15 +0300 Subject: [PATCH 6/7] Update CHANGELOG.md Co-authored-by: Tyler Yahn --- CHANGELOG.md | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 09623ba09..399f9abd6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -27,7 +27,14 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http - Update generated offsets. ([#186](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/186)) - Reduce Docker image size by using different base image. ([#182](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/182)) - Support for multiple processes in BPF FS. ([#211](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/211)) -- Fix offset tracker to build binaries for go stdlib as well. DownloadBinary() now has an additional flag indicating whether it'll build a dummy app for go stdlib or not - this will cause a different go.mod file to be used. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) +- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/downloader".DownloadBinary` has changed. + It now has an additional flag indicating whether it'll build a dummy app for Go stdlib packages or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) +- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/target".New` has changed. + It now accepts a flag to determine if the returned `Data` is from the Go stdlib or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) + +### Fixed + +- The offset tracker can once again build binaries for the Go stdlib. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) ## [v0.2.1-alpha] - 2023-05-15 From e19e2f945fa701915f71c9a9f1ad4a340c5ab4e8 Mon Sep 17 00:00:00 2001 From: Ron Federman Date: Fri, 18 Aug 2023 17:07:15 +0300 Subject: [PATCH 7/7] Fix changelog --- CHANGELOG.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 399f9abd6..b08f86aa7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,9 +8,17 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http ## [Unreleased] +### Changed + +- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/downloader".DownloadBinary` has changed. + It now has an additional flag indicating whether it'll build a dummy app for Go stdlib packages or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) +- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/target".New` has changed. + It now accepts a flag to determine if the returned `Data` is from the Go stdlib or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) + ### Fixed - Fix context propagation across different goroutines. ([#118](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/118)) +- The offset tracker can once again build binaries for the Go stdlib. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) ## [v0.2.2-alpha] - 2023-07-12 @@ -27,14 +35,6 @@ OpenTelemetry Go Automatic Instrumentation adheres to [Semantic Versioning](http - Update generated offsets. ([#186](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/186)) - Reduce Docker image size by using different base image. ([#182](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/182)) - Support for multiple processes in BPF FS. ([#211](https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/211)) -- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/downloader".DownloadBinary` has changed. - It now has an additional flag indicating whether it'll build a dummy app for Go stdlib packages or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) -- The function signature of `"go.opentelemetry.io/auto/offsets-tracker/target".New` has changed. - It now accepts a flag to determine if the returned `Data` is from the Go stdlib or not. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) - -### Fixed - -- The offset tracker can once again build binaries for the Go stdlib. ([#256]https://github.com/open-telemetry/opentelemetry-go-instrumentation/pull/256) ## [v0.2.1-alpha] - 2023-05-15