# Advanced debugging This guide covers more advanced debugging topics such as collecting runtime profiling data from GitOps Toolkit components. As a user, this page normally should be a last resort, but you may be asked by a maintainer to share a [collected profile](#collecting-a-profile) to debug e.g. performance issues. ## Pprof The [GitOps Toolkit components](../components/index.md) serve [`pprof`](https://golang.org/pkg/net/http/pprof/) runtime profiling data on their metrics HTTP server (default `:8080`). ### Endpoints | Endpoint | Path | |-------------|------------------------| | Index | `/debug/pprof/` | | CPU profile | `/debug/pprof/profile` | | Symbol | `/debug/pprof/symbol` | | Trace | `/debug/pprof/trace` | ### Collecting a profile To collect a profile, port-forward to the component's metrics endpoint and collect the data from the [endpoint](#endpoints) of choice: ```console $ kubectl port-forward -n <namespace> deploy/<component> 8080 $ curl -Sk -v http://localhost:8080/debug/pprof/heap > heap.out ``` The collected profile [can be analyzed using `go`](https://blog.golang.org/pprof), or shared with one of the maintainers. ## Resource usage As `kubectl top` gives a limited (and at times inaccurate) overview of resource usage, it is often better to make use of the Grafana metrics to gather insights. See [monitoring](../guides/monitoring.md) for a guide on how to visualize this data with a Grafana dashboard.