/docker-delve

Delve (golang debugger) containerized

Primary LanguageDockerfile

Go Delve Image

Source: https://github.com/multi-io/docker-delve

Usually run with the binary to be debugged mounted into the container. You could also copy the dlv binary (which is linked statically) out of the container into the to-be-debugged container, e.g. if you use this image in a K8s InitContainer.

There are two images built from this source: delve and delve-sumo. The former contains only dlv (in a alpine base image, ~25 MB), the latter also contains telepresence, kubectl and other random debugging utils (~950 MB).

IMPORTANT: You need to run the container with --security-opt seccomp:unconfined. Otherwise Delve will abort with could not launch process: fork/exec <binary>: operation not permitted.

Binaries need to be compiled with debugging symbols (-gcflags 'all=-N -l') for Delve to work with them.

Sample invocation, assuming the binary to be debugged is located at output/binary on the host:

docker run --security-opt seccomp:unconfined -v `pwd`/output:/output -p 2345:2345 oklischat/delve --listen=:2345 --headless=true --api-version=2 exec /output/binary -- <arguments>

You should now be able to connect any debugging client running on the host (e.g delve itself, or an IDE like Goland) to the debugged process at localhost:2345.