forgejo/modules/process
Gusted 3f44b97b5f
feat: add limited execution tracing support
- For every process that is spawned (every new non-trivial goroutine
such as http requests, queues or tasks) start a [execution
tracer](https://pkg.go.dev/runtime/trace). This allows very precise
diagnosis of how each individual process over a time period.
- It's safe and [fast](https://go.dev/blog/execution-traces-2024#low-overhead-tracing) to
be run in production, hence no setting to disable this. There's only
noticable overhead when tracing is actually performed and not continuous.
- Proper tracing support would mean the codebase would be full of
`trace.WithRegion` and `trace.Log`, which feels premature for this patch
as there's no real-world usage yet to indicate which places would need
this the most. So far only Git commands and SQL queries receive somewhat
proper tracing support given that these are used throughout the codebase.
- Make git commands a new process type.
- Add tracing to diagnosis zip file.
2025-01-05 04:07:49 +01:00
..
context.go Replace interface{} with any (#25686) 2023-07-04 18:36:08 +00:00
error.go Implement FSFE REUSE for golang files (#21840) 2022-11-27 18:20:29 +00:00
manager.go feat: add limited execution tracing support 2025-01-05 04:07:49 +01:00
manager_exec.go Implement FSFE REUSE for golang files (#21840) 2022-11-27 18:20:29 +00:00
manager_stacktraces.go chore: avoid trying to stream data 2025-01-05 04:07:49 +01:00
manager_stacktraces_test.go chore: avoid trying to stream data 2025-01-05 04:07:49 +01:00
manager_test.go Replace assert.Fail with assert.FailNow (#27578) 2023-10-11 11:02:24 +00:00
manager_unix.go Implement FSFE REUSE for golang files (#21840) 2022-11-27 18:20:29 +00:00
process.go feat: add limited execution tracing support 2025-01-05 04:07:49 +01:00