Actions
Story #13048
openRefactor crunch2 logging
Status:
New
Priority:
Normal
Assigned To:
-
Category:
-
Target version:
-
Start date:
Due date:
% Done:
0%
Estimated time:
Story points:
2.0
Release:
Release relationship:
Auto
Description
Functionally, source:services/crunch-run is doing a reasonable job. However, the way it's implemented makes it difficult to make some of the changes we want.
Relevant issues- #10181 save logs to keep periodically while a container is running (not just after it exits & saves staged outputs)
- #13005 timestamps are sometimes wrong/confusing because of throttle behavior
- #13100 source:services/crunch-run and source:sdk/go/crunchrunner should drop their custom manifest-writing code, now that we have generalized write support in #12483
- The implementation is more complicated / harder to follow than it should be, given the low complexity of the problem it's solving
- Refactor the various functional aspects (add timestamps, throttle, write to apiserver) into modular parts that communicate through simple interfaces like io.Writer.
- Use io.MultiWriter from stdlib, instead of custom routing built into the processing modules.
- Use
(*arvados.Collection)FileSystem()
to open/write log files (and staged outputs? → deleteupload*.go
) - Drop the pretense of splitting long lines (apparently this isn't needed; MaxLogLine seems to have been disconnected 2 years ago in b719ef57055ba2fd06c7a1377cc0d47ee5df935e)
Actions