The Debug Framework contributes Java debug configuration to the application at runtime. Note: This framework is only useful in Diego-based containers with SSH access enabled.
Detection Criterion | enabled set in the config/debug.yml file |
Tags | debug=<port> |
For general information on configuring the buildpack, including how to specify configuration values through environment variables, refer to Configuration and Extension.
The framework can be configured by creating or modifying the config/debug.yml
file in the buildpack fork.
Name | Description |
---|---|
enabled |
Whether to enable Java debugging |
port |
The port that the debug agent will listen on. Defaults to 8000 . |
suspend |
Whether to suspend execution until a debugger has attached. Note, enabling this may cause application start to timeout and be restarted. |
After starting an application with debugging enabled, an SSH tunnel must be created to the container. To create that SSH container, execute the following command:
$ cf ssh -N -T -L <LOCAL_PORT>:localhost:<REMOTE_PORT> <APPLICATION_NAME>
The REMOTE_PORT
should match the port
configuration for the application (8000
by default). The LOCAL_PORT
can be any open port on your computer, but typically matches the REMOTE_PORT
where possible.
Once the SSH tunnel has been created, your IDE should connect to localhost:<LOCAL_PORT>
for debugging.