Use PyCharm with X11 Forwarding and Run:ai¶
X11 is a window system for the Unix operating systems. X11 forwarding allows executing a program remotely through an SSH connection. Meaning, the executable file itself is hosted on a different machine than where the graphical interface is being displayed. The graphical windows are forwarded to your local machine through the SSH connection.
This section is about setting up X11 forwarding from a Run:ai-based container to a PyCharm IDE on a remote machine.
Submit a Workload¶
You will need your image to run an SSH server (e.g OpenSSH). For the purposes of this document, we have created an image named
gcr.io/run-ai-demo/quickstart-x-forwarding. The image runs:
- SSH Daemon configured for X11Forwarding
- OpenCV python library for image handling
Details on how to create the image are here. The image is configured to use the
root user and password for SSH.
Run the following command to connect to the container as if it were running locally:
The terminal will show the connection:
The job 'xforward-remote' has been submitted successfully You can run `runai describe job xforward-remote -p team-a` to check the job status INFO Waiting for job to start Waiting for job to start Waiting for job to start Waiting for job to start INFO Job started Open access point(s) to service from localhost:2222 Forwarding from [::1]:2222 -> 22
- The Job starts an sshd server on port 22.
- The connection is redirected to the local machine (127.0.0.1) on port 2222
Setup the X11 Forwarding Tunnel¶
Connect to the new Job by running:
The ssh terminal should remain active throughout the session.
- Under PyCharm | Preferences go to: Project | Python Interpreter
- Add a new SSH Interpreter.
- As Host, use
localhost. Change the port to the above (
2222) and use the Username
- You will be prompted for a password. Enter
- Make sure to set the correct path of the Python binary. In our case it's
Apply your settings.
Under PyCharm configuration set the following environment variables:
DISPLAY- set environment variable you copied before
HOME- In our case it's
/root. This is required for the X11 authentication to work.
Run your code. You can use our sample code here.