SSH X11 Forwarding
Technical Background
X11 forwarding allows you to run a graphical application on a remote host but display its window on your local desktop, all over a secure SSH connection. This is useful when the remote host is locked down (e.g., only SSH allowed, HTTP blocked) but you still need to use graphical tools, like a web browser, without exposing new network ports.
Solution
Server Setup
- 
Deploy a server with the same configuration as in 03 Server Security Improvement 
- 
Install and start Nginx on the server: bash apt install nginx -y systemctl status nginx
- 
Check that Nginx is reachable from the server itself: bash curl http://localhost
- 
In the firewall, allow only SSH (TCP port 22) and remove HTTP (TCP port 80) 
- 
Test that HTTP bash curl http://<server-ip>Note Expected result: connection refused or timeout
- 
Install xauth, which is required for managing X11 authentication:bash apt install xauth
Using X11 Forwarding
If your local machine is a linux system X11 is included by default. On other system check how to install the appropiate tools.
!!! Warning
    Make sure your local X11 Server is running.
- 
Connect with X11 Forwarding using the -Yflag:bash ssh -Y root@<your-server-ip>Info This enables secure X11 forwarding. 
- 
Install Firefox on the server: bash apt install firefox-esrWarning This may take some time, so using a slightly larger server instance is recommended. 
- 
Run Firefox: firefoxNote The Firefox window should appear on your local desktop, even though it runs on the remote server. Note If the GUI isn't showing up make sure that the X11 server is running and that your local machine has the appropiate access.