Tutorial: Attach to a remote process
RubyMine enables you to attach to a running process on a local or remote computer. This capability allows you to debug applications that cannot be launched directly from the IDE.
In this topic, we’ll use this capability to debug a sample Rails application running on a remote machine.
In this tutorial, we'll use two machines to demonstrate debugging of the remote application:
Local machine: Mac with macOS, with RubyMine installed.
Remote machine: The Ubuntu machine with enabled SSH access and the Ruby interpreter installed. Note that GDB should also be installed on a remote machine.
In our tutorial, the remote computer has the sample-web-server name.
tip
For the remote macOS machine, LLDB should be installed.
On both machines, we’ll use the jetbrains user’s home directories to store source code.
First of all, we need to clone and run the sample application on a remote machine. To do this, connect to a remote machine and use instructions from the Getting started chapter. After performing the required steps, use the rails server
command to run an application:
data:image/s3,"s3://crabby-images/69f3e/69f3ed83ed4d60e1c4b801f7c788715483422227" alt="Remote session Remote session"
After running the sample application on a remote machine, launch RubyMine and open the same application on a local machine using this instruction: Check out a project from a remote host (git clone). In URL, insert the following address: https://github.com
data:image/s3,"s3://crabby-images/f2c05/f2c05865b4100e7dda0cca876562ef3ed952a9cb" alt="Get from Version Control dialog Get from Version Control dialog"
In this part, we’ll configure a remote interpreter using SSH.
Open the Settings dialog CtrlAlt0S, go to the Language & Frameworks | Ruby SDK and Gems page, click the
button and select Remote Interpreter or Version Manager from the list:
In the invoked dialog, select SSH Credentials and specify parameters in the following way:
SSH configuration: Click the ellipsis button to create an SSH configuration for connecting to a remote machine.
Ruby or version manager path: Here you should specify the path to the Ruby interpreter or the version manager executable. In this tutorial, we use rbenv on a remote machine.
After you have specified all the settings, click OK.
If you specified a path to the version manager executable in the previous dialog, RubyMine suggests selecting the required Ruby interpreter. In this step, you need to choose the interpreter used to run a remote application.
Click OK and select the added SDK in the Ruby SDK and Gems page.
The final thing you need to do is to specify mappings between files of a local and remote project. To do this, click the Edit Path Mappings
button. In the Edit Project Path Mappings dialog, specify the local and remote project root paths.
tip
If necessary, you may specify not project root paths but only folders containing sources required for debugging.
In our case, the paths will look as follows:
Local Path:
/Users /jetbrains /RubymineProjects /sample_rails_app Remote Path:
/home /deploy /sample_rails_app
Click OK in this dialog and then click OK in the Settings dialog. Now we are ready to attach to a remote process and debug the application.
Now we are ready to debug a remote application.
Open the users_controller.rb file and set a breakpoint within the create method next to the line where a new user is created.
Click Run in the main menu and select the Attach to Process… command.
In the invoked dialog, select the remote connection in the SSH group (sample-web-server@22 in our case) and choose the puma process:
The Console tab will display the debugger output:
To debug an application, open the browser on a local machine and specify the application address. In our case, it will be http://sample-web-server:3000.
data:image/s3,"s3://crabby-images/6b1b4/6b1b49882f19eca12b52c7824601e65fdb4028ec" alt="Sign up page Sign up page"
Click the Sign up now! button. On the Sign up page, enter the required user parameters and click Create my account.
data:image/s3,"s3://crabby-images/f0e68/f0e68153d4a44cfeea945d2105e755a91c264a8c" alt="User credentials User credentials"
The debugger pauses its session on a breakpoint and enables you to examine the remote application state.
data:image/s3,"s3://crabby-images/5e050/5e050c697e3e5b82c78346cd8b2d85a0d52e0ca6" alt="Debugging a remote application Debugging a remote application"
For instance, you can check user parameters specified on the Sign up page.
If you encounter any issues on an attempt to attach to a process, try the following solutions:
Make sure that the remote application is run with the same Ruby interpreter as configured for a debugged project.
Try to increase the debug connection timeout. To do this, open the Settings dialog CtrlAlt0S, go to the Build, Execution, Deployment | Debugger page, and use the Debug connection timeout option.
Thanks for your feedback!