-
Notifications
You must be signed in to change notification settings - Fork 17.8k
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
cmd/go: tests frequently timing out on dragonfly-amd64
since CL 412394
#53577
Comments
Change https://go.dev/cl/414614 mentions this issue: |
The cmd/go tests have been timing out frequently on this builder. We are still investigating the root cause. For golang/go#53577. Change-Id: I841117e8c2cff7296869d7beedced364714b7cf9 Reviewed-on: https://go-review.googlesource.com/c/build/+/414614 Reviewed-by: David Chase <[email protected]> Auto-Submit: Bryan Mills <[email protected]> TryBot-Result: Gopher Robot <[email protected]> Run-TryBot: Bryan Mills <[email protected]>
Change https://go.dev/cl/416134 mentions this issue: |
Change https://go.dev/cl/416178 mentions this issue: |
Change https://go.dev/cl/416179 mentions this issue: |
load.loadPackageData was only using an index for modules, not for standard library packages. Other parts of the code were using the index, so there was some benefit, but not as much as you'd hope. With the index disabled, the Script/work test takes 2.2s on my Mac. With the index enabled before this CL, it took 2.0s. With the index enabled after this CL, it takes 1.6s. Before this CL, the Script/work test issued: 429 IsDir 19 IsDirWithGoFiles 7 Lstat 9072 Open 993 ReadDir 256 Stat 7 Walk 3 indexModule 24 openIndexModule 525 openIndexPackage After this CL, it issued: 19 IsDirWithGoFiles 7 Lstat 60 Open 606 ReadDir 256 Stat 7 Walk 3 indexModule 24 openIndexModule 525 openIndexPackage This speedup helps the Dragonfly builder, which has very slow file I/O and is timing out since a recent indexing change. Times for go test -run=Script/^work$ on the Dragonfly builder: 50s before indexing changes 31s full module indexing of std 46s per-package indexing of std It cuts the time for go test -run=Script/^work$ from 44s to 20s. For #53577. Change-Id: I7189a77fc7fdf61de3ab3447efc4e84d1fc52c25 Reviewed-on: https://go-review.googlesource.com/c/go/+/416134 Reviewed-by: Bryan Mills <[email protected]>
For a large module, opening the index was populating tables with entries for every package in the module. If we are only using a small number of those packages, this is wasted work that can dwarf the benefit from the index. This CL changes the index reader to avoid loading all packages at module index open time. It also refactors the code somewhat for clarity. It also removes some duplication by defining that a per-package index is a per-module index containing a single package, rather than having two different formats and two different decoders. It also changes the string table to use uvarint-prefixed data instead of having to scan for a NUL byte. This makes random access to long strings more efficient - O(1) instead of O(n) - and can significantly speed up the strings.Compare operation in the binary search looking for a given package. Also add a direct test of the indexing code. For #53577. Change-Id: I7428d28133e4e7fe2d2993fa014896cd15af48af Reviewed-on: https://go-review.googlesource.com/c/go/+/416178 Reviewed-by: Bryan Mills <[email protected]>
fsys.Walk is cloned from filepath.Walk, which has always handled a walk of a directory by reading the full directory before calling the callback on the directory itself. So if the callback returns fs.SkipDir, those entries are thrown away, but the expense of reading them was still incurred. (Worse, this is the expensive directory read that also calls Stat on every entry.) On machines with slow file system I/O, these reads are particularly annoying. For example, if I do go list m... there is a call to filepath.Walk that is told about $GOROOT/src/archive and responds by returning filepath.SkipDir because archive does not start with m, but it only gets the chance to do that after the archive directory has been read. (Same for all the other top-level directories.) Even something like go list github.com/foo/bar/... reads every top-level $GOPATH/src directory. When we designed filepath.WalkDir, one of the changes we made was to allow calling the callback twice for a directory: once before reading it, and then possibly again if the read produces an error (uncommon). This CL changes fsys.Walk to use that same model. None of the callbacks need changing, but now the $GOROOT/src/archive and other top-level directories won't be read when evaluating a pattern like 'm...'. For #53577. Fixes #53765. Change-Id: Idfa3b9e2cc335417bfd9d66dd584cb16f92bd12e Reviewed-on: https://go-review.googlesource.com/c/go/+/416179 Run-TryBot: Russ Cox <[email protected]> Reviewed-by: Bryan Mills <[email protected]> TryBot-Result: Gopher Robot <[email protected]>
Change https://go.dev/cl/417094 mentions this issue: |
The gccgo compiler does not load standard-library packages from GOROOT/src, so we cannot load those packages from the GOROOT/src index when using that compiler. This fixes TestScript/gccgo_link_c (and perhaps other gccgo tests) when a 'gccgo' executable is present. Unfortunately, only a few builders caught the broken test because 'gccgo' is not installed on most Go project builders (see #35786). For #53577. Fixes #53815. Change-Id: I11a5cf6dbf4ac9893c4d02bd6ab7ef60f67b1e87 Reviewed-on: https://go-review.googlesource.com/c/go/+/417094 TryBot-Result: Gopher Robot <[email protected]> Run-TryBot: Bryan Mills <[email protected]> Reviewed-by: Russ Cox <[email protected]>
Change https://go.dev/cl/419084 mentions this issue: |
load.loadPackageData was only using an index for modules, not for standard library packages. Other parts of the code were using the index, so there was some benefit, but not as much as you'd hope. With the index disabled, the Script/work test takes 2.2s on my Mac. With the index enabled before this CL, it took 2.0s. With the index enabled after this CL, it takes 1.6s. Before this CL, the Script/work test issued: 429 IsDir 19 IsDirWithGoFiles 7 Lstat 9072 Open 993 ReadDir 256 Stat 7 Walk 3 indexModule 24 openIndexModule 525 openIndexPackage After this CL, it issued: 19 IsDirWithGoFiles 7 Lstat 60 Open 606 ReadDir 256 Stat 7 Walk 3 indexModule 24 openIndexModule 525 openIndexPackage This speedup helps the Dragonfly builder, which has very slow file I/O and is timing out since a recent indexing change. Times for go test -run=Script/^work$ on the Dragonfly builder: 50s before indexing changes 31s full module indexing of std 46s per-package indexing of std It cuts the time for go test -run=Script/^work$ from 44s to 20s. For golang#53577. Change-Id: I7189a77fc7fdf61de3ab3447efc4e84d1fc52c25 Reviewed-on: https://go-review.googlesource.com/c/go/+/416134 Reviewed-by: Bryan Mills <[email protected]>
For a large module, opening the index was populating tables with entries for every package in the module. If we are only using a small number of those packages, this is wasted work that can dwarf the benefit from the index. This CL changes the index reader to avoid loading all packages at module index open time. It also refactors the code somewhat for clarity. It also removes some duplication by defining that a per-package index is a per-module index containing a single package, rather than having two different formats and two different decoders. It also changes the string table to use uvarint-prefixed data instead of having to scan for a NUL byte. This makes random access to long strings more efficient - O(1) instead of O(n) - and can significantly speed up the strings.Compare operation in the binary search looking for a given package. Also add a direct test of the indexing code. For golang#53577. Change-Id: I7428d28133e4e7fe2d2993fa014896cd15af48af Reviewed-on: https://go-review.googlesource.com/c/go/+/416178 Reviewed-by: Bryan Mills <[email protected]>
fsys.Walk is cloned from filepath.Walk, which has always handled a walk of a directory by reading the full directory before calling the callback on the directory itself. So if the callback returns fs.SkipDir, those entries are thrown away, but the expense of reading them was still incurred. (Worse, this is the expensive directory read that also calls Stat on every entry.) On machines with slow file system I/O, these reads are particularly annoying. For example, if I do go list m... there is a call to filepath.Walk that is told about $GOROOT/src/archive and responds by returning filepath.SkipDir because archive does not start with m, but it only gets the chance to do that after the archive directory has been read. (Same for all the other top-level directories.) Even something like go list github.com/foo/bar/... reads every top-level $GOPATH/src directory. When we designed filepath.WalkDir, one of the changes we made was to allow calling the callback twice for a directory: once before reading it, and then possibly again if the read produces an error (uncommon). This CL changes fsys.Walk to use that same model. None of the callbacks need changing, but now the $GOROOT/src/archive and other top-level directories won't be read when evaluating a pattern like 'm...'. For golang#53577. Fixes golang#53765. Change-Id: Idfa3b9e2cc335417bfd9d66dd584cb16f92bd12e Reviewed-on: https://go-review.googlesource.com/c/go/+/416179 Run-TryBot: Russ Cox <[email protected]> Reviewed-by: Bryan Mills <[email protected]> TryBot-Result: Gopher Robot <[email protected]>
The gccgo compiler does not load standard-library packages from GOROOT/src, so we cannot load those packages from the GOROOT/src index when using that compiler. This fixes TestScript/gccgo_link_c (and perhaps other gccgo tests) when a 'gccgo' executable is present. Unfortunately, only a few builders caught the broken test because 'gccgo' is not installed on most Go project builders (see golang#35786). For golang#53577. Fixes golang#53815. Change-Id: I11a5cf6dbf4ac9893c4d02bd6ab7ef60f67b1e87 Reviewed-on: https://go-review.googlesource.com/c/go/+/417094 TryBot-Result: Gopher Robot <[email protected]> Run-TryBot: Bryan Mills <[email protected]> Reviewed-by: Russ Cox <[email protected]>
None of the individual scripts was left running for longer than 30s or so, so it appears that the
cmd/go
tests in general have gotten much slower on this builder.We had thought that CL 413634 and/or CL 413815 would fix the problem, but that appears not to have borne out.
greplogs -l -e \(\?ms\)\\Adragonfly-amd64.\*FAIL\\s+cmd/go\\s+\\d\{4}\\.\\d\*s --since=2022-04-01 --details
2022-06-26T22:12:19-351e0f4/dragonfly-amd64
2022-06-26T00:21:33-666d736/dragonfly-amd64
2022-06-25T19:08:51-3b594b9/dragonfly-amd64
2022-06-25T19:07:01-4f45ec5/dragonfly-amd64
2022-06-24T23:50:20-41e1d90/dragonfly-amd64
2022-06-24T22:08:17-bd47539/dragonfly-amd64
2022-06-24T21:22:43-6b6c64b/dragonfly-amd64
2022-06-24T18:54:27-b9c4d94/dragonfly-amd64
2022-06-24T17:48:24-73475ef/dragonfly-amd64
2022-06-24T17:45:41-3e58ef6/dragonfly-amd64
2022-06-24T00:37:46-d38f1d1/dragonfly-amd64
2022-06-23T19:05:29-de5329f/dragonfly-amd64
2022-06-22T23:27:17-2e773a3/dragonfly-amd64
2022-06-22T22:14:02-ff17b7d/dragonfly-amd64
2022-06-22T20:56:07-bdab4cf/dragonfly-amd64
2022-06-22T19:56:09-aca37d1/dragonfly-amd64
2022-06-21T15:00:37-19ed442/dragonfly-amd64
2022-06-20T18:39:08-3fcbfb0/dragonfly-amd64
2022-06-17T22:44:22-ec58e3f/dragonfly-amd64
2022-06-17T21:38:40-103cc66/dragonfly-amd64
2022-06-17T21:35:36-d42a488/dragonfly-amd64
2022-06-17T21:21:58-9e2f289/dragonfly-amd64
2022-06-17T21:21:26-dd2d00f/dragonfly-amd64
2022-06-17T15:02:55-6c25ba6/dragonfly-amd64
2022-06-16T21:58:40-9068c68/dragonfly-amd64
2022-06-16T21:25:35-7bad615/dragonfly-amd64
2022-06-16T20:59:51-f38a580/dragonfly-amd64
2022-06-16T20:01:10-635b124/dragonfly-amd64
2022-06-16T18:29:19-ef808ae/dragonfly-amd64
2022-06-16T16:44:35-74f1fa6/dragonfly-amd64
2022-06-16T16:22:37-bcce8ef/dragonfly-amd64
2022-06-16T01:03:59-ecc268a/dragonfly-amd64
2022-06-15T21:24:24-91baf5c/dragonfly-amd64
2022-06-15T21:18:07-0e3d0c9/dragonfly-amd64
2022-06-15T21:18:06-74bf90c/dragonfly-amd64
2022-06-15T21:16:14-0cd0c12/dragonfly-amd64
2022-06-15T20:07:10-937fa50/dragonfly-amd64
2022-06-15T17:37:53-c2c76c6/dragonfly-amd64
2022-06-15T17:13:55-36147dd/dragonfly-amd64
(39 matching logs)
(CC @golang/dragonfly)
@rsc is planning to investigate.
The text was updated successfully, but these errors were encountered: