Skip to main content

attach to a process precisely after a successful execve() / execveat()

Project description

PyPI

gdb-pounce

Wait until a process with a certain name starts and attach to it with gdb. While for many use cases

while ! pidof "$NAME"; do :; done; gdb -p "$(pidof "$NAME")"

is sufficient, gdb-pounce will stop right at the loader entry point, as if the process was started under gdb in the first place.

When is this useful?

When an interesting process (usually a part of some complex software) starts in a non-trivial environment, for example:

  • As a specific user.

  • In a specific namespace.

  • With additional environment variables.

  • With additional file descriptors.

  • While another process is in a specific state.

and we need to debug its initialization.

How do I use it?

python3 -m pip install --user gdb-pounce
sudo env "PATH=$PATH" gdb-pounce [GDB OPTION]... [NAME]

Prerequisites

pounce?

gdb-pounce lies in wait for its victim process. The very moment the process appears, gdb-pounce pounces at it and seizes it, leaving it no chance to react.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

gdb_pounce-0.0.4-py3-none-any.whl (5.3 kB view details)

Uploaded Python 3

File details

Details for the file gdb_pounce-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: gdb_pounce-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 5.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.5

File hashes

Hashes for gdb_pounce-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 cc6494dd075dcdf1e4a7dc0a64d02154c598ea7a9b009f7c9d320ccc96cdcaa5
MD5 5d9c56be35653b073f44e27a0d6a7287
BLAKE2b-256 7a2e4124164dbb9e556661a2ecb960a1f668f0212bd3dead20ccb929c5b0aebc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page