Connect to Linux VMs using Cloud VPN or Cloud Interconnect
Stay organized with collections
Save and categorize content based on your preferences.
Linux
This document describes how to connect to a virtual machine (VM) instance
through its internal IP address, from an on-premises network that uses
Cloud VPN or
Cloud Interconnect
to connect to the VM's VPC network.
Connecting to a VM using its internal IP address is useful if the VM doesn't
have an external IP address. If the VM does have an external IP address,
connect to the VM using its external IP address.
If your on-premises network isn't connected to your VM's VPC
network and you need to connect to your VM's internal IP address, review the
other methods listed in
Connection options for internal-only VMs.
Supported operating systems
These connection methods are supported for all
public Linux images that are available on
Compute Engine. For Fedora CoreOS images, you must
set up SSH access
before you can use these methods.
Connect to VMs
To connect to a VM, complete the steps in one of the following tabs.
At the bottom of the Google Cloud console, a
Cloud Shell
session starts and displays a command-line prompt. Cloud Shell is a shell environment
with the Google Cloud CLI
already installed and with values already set for
your current project. It can take a few seconds for the session to initialize.
Connect to the VM by running the following command:
gcloud compute ssh VM-NAME \
--internal-ip
Replace VM_NAME with the name of the VM that you want to connect to.
IAP Desktop
To connect to a VM using IAP Desktop, do the following:
Connect to the
VM by running the following command:
ssh -i PATH_TO_PRIVATE_KEYUSERNAME@INTERNAL_IP
Replace the following:
PATH_TO_PRIVATE_KEY: the path to the private SSH key file
that corresponds to the public key you added to the VM.
USERNAME:
your
username. If you manage your SSH keys in
metadata, the username is what you specified when you
created the SSH key.
For
OS Login accounts, the username is
defined in your Google profile.
For example, cloudysanfrancisco_example_com or cloudysanfrancisco.
INTERNAL_IP: the internal IP address of the VM.
PuTTY app
Connect through a VM's internal IP address using PuTTY, by doing the following:
Open the PuTTY app. A connection configuration window opens.
In the Host Name field, enter the username associated with the SSH key, and
the
internal IP address
of the VM that you want to connect to. Use the following format:
USERNAME@INTERNAL_IP
Replace the following:
USERNAME:
your
username. If you manage your SSH keys in
metadata, the username is what you specified when you
created the SSH key.
For
OS Login accounts, the username is
defined in your Google profile.
For example, cloudysanfrancisco_example_com or cloudysanfrancisco.
INTERNAL_IP: the internal IP address of the VM.
In the Category menu, navigate to Connection >
SSH > Auth.
In the Private key file for authentication field, select the private SSH key
file that corresponds to the public key you added to the VM.
Click Open to connect to the VM.
Troubleshooting
To find methods for diagnosing and resolving failed SSH connections, see
Troubleshooting SSH.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-26 UTC."],[[["\u003cp\u003eThis guide outlines methods for connecting to a Linux virtual machine (VM) using its internal IP address, specifically from an on-premises network linked via Cloud VPN or Cloud Interconnect.\u003c/p\u003e\n"],["\u003cp\u003eConnecting via internal IP is particularly useful when the VM lacks an external IP address, though alternative connection methods exist for internal-only VMs.\u003c/p\u003e\n"],["\u003cp\u003eThe document supports connections to all public Linux images available on Compute Engine, and details connection methods using gcloud, IAP Desktop, OpenSSH clients, and PuTTY.\u003c/p\u003e\n"],["\u003cp\u003eThe guide provides instructions on how to initiate SSH connections using various methods, including command-line tools and graphical interfaces.\u003c/p\u003e\n"],["\u003cp\u003eTroubleshooting resources are available to help resolve any issues that may occur when connecting via SSH to a VM.\u003c/p\u003e\n"]]],[],null,["Linux\n\n*** ** * ** ***\n\nThis document describes how to connect to a virtual machine (VM) instance\nthrough its internal IP address, from an on-premises network that uses\n[Cloud VPN](/network-connectivity/docs/vpn/concepts/overview) or\n[Cloud Interconnect](/network-connectivity/docs/interconnect/concepts/overview)\nto connect to the VM's VPC network.\n\nConnecting to a VM using its internal IP address is useful if the VM doesn't\nhave an external IP address. If the VM does have an external IP address,\n[connect to the VM using its external IP address](/compute/docs/instances/connecting-to-instance).\nIf your on-premises network isn't connected to your VM's VPC\nnetwork and you need to connect to your VM's internal IP address, review the\nother methods listed in\n[Connection options for internal-only VMs](/compute/docs/connect/ssh-internal-ip).\n\nSupported operating systems\n\nThese connection methods are supported for all\n[public Linux images](/compute/docs/images/os-details) that are available on\nCompute Engine. For Fedora CoreOS images, you must\n[set up SSH access](https://docs.fedoraproject.org/en-US/fedora-coreos/tutorial-containers/)\nbefore you can use these methods.\n\nConnect to VMs\n\nTo connect to a VM, complete the steps in one of the following tabs. \n\ngcloud\n\nConnect to a VM using SSH by running the\n[`gcloud compute ssh` command](/sdk/gcloud/reference/compute/ssh) with the\n[`--internal-ip` flag](/sdk/gcloud/reference/compute/ssh#--internal-ip):\n\n1. In the Google Cloud console, activate Cloud Shell.\n\n [Activate Cloud Shell](https://console.cloud.google.com/?cloudshell=true)\n\n\n At the bottom of the Google Cloud console, a\n [Cloud Shell](/shell/docs/how-cloud-shell-works)\n session starts and displays a command-line prompt. Cloud Shell is a shell environment\n with the Google Cloud CLI\n already installed and with values already set for\n your current project. It can take a few seconds for the session to initialize.\n2. Connect to the VM by running the following command:\n\n ```\n gcloud compute ssh VM-NAME \\\n --internal-ip\n ```\n3. Replace \u003cvar translate=\"no\"\u003eVM_NAME\u003c/var\u003e with the name of the VM that you want to connect to.\n\n| **Note:** When you connect to VMs using the gcloud CLI, Compute Engine creates a persistent SSH key for you. For more information about SSH keys, see [SSH connections to Linux VMs](/compute/docs/instances/ssh).\n\nIAP Desktop\n\nTo connect to a VM using IAP Desktop, do the following:\n\n1.\n [Install IAP Desktop](https://github.com/GoogleCloudPlatform/iap-desktop/)\n on your workstation if you haven't already.\n\n2.\n Open IAP Desktop. The **Add projects** window opens.\n\n3.\n\n When prompted, sign in using the Google account that has access to the project with the VMs\n you want to connect to.\n\n4.\n In the **Add projects** window, enter the project ID or name of the\n project that contains the VMs you want to connect to.\n\n5.\n In the **Project Explorer** window, right-click the name of the VM that\n you want to connect to and select **Connection settings**.\n\n6.\n In the **Connection settings** window, set **Connect via**\n to **Vpc**.\n\n7.\n In the **Project Explorer** window, right-click the name of the VM\n again and select **Connect** to connect to the VM.\n\nOpenSSH clients\n\nConnect through a VM's internal IP address from an OpenSSH client, by doing the following:\n\n1. [Add an SSH key to the VM](/compute/docs/connect/add-ssh-keys) if you haven't already.\n2. In the Google Cloud console, go to the **VM Instances** page and find the\n\n internal IP address\n\n of the\n\n VM that you want to connect to.\n\n [Go to VM Instances](https://console.cloud.google.com/compute/instances)\n3. Open a terminal on your workstation.\n4. Connect to the\n\n VM by running the following command:\n\n ```\n ssh -i PATH_TO_PRIVATE_KEY USERNAME@INTERNAL_IP\n ```\n\n Replace the following:\n - \u003cvar translate=\"no\"\u003ePATH_TO_PRIVATE_KEY\u003c/var\u003e: the path to the private SSH key file that corresponds to the public key you added to the VM.\n - \u003cvar translate=\"no\"\u003eUSERNAME\u003c/var\u003e: your username. If you manage your SSH keys in metadata, the username is what you specified when you [created the SSH key](/compute/docs/connect/create-ssh-keys). For OS Login accounts, the username is [defined in your Google profile](/compute/docs/connect/add-ssh-keys#os-login). For example, `cloudysanfrancisco_example_com` or `cloudysanfrancisco`.\n - \u003cvar translate=\"no\"\u003eINTERNAL_IP\u003c/var\u003e: the internal IP address of the VM.\n\nPuTTY app\n\nConnect through a VM's internal IP address using PuTTY, by doing the following:\n\n1. [Add an SSH key](/compute/docs/connect/add-ssh-keys) to the VM if you haven't already.\n2. If your workstation doesn't already have the PuTTY app installed, [download the PuTTY package files](http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html).\n3. In the Google Cloud console, go to the **VM Instances** page and find the\n\n internal IP address\n\n of the VM that you want to connect to.\n\n [Go to VM Instances](https://console.cloud.google.com/compute/instances)\n4. Open the PuTTY app. A connection configuration window opens.\n5. In the `Host Name` field, enter the username associated with the SSH key, and\n the\n\n internal IP address\n\n of the VM that you want to connect to. Use the following format:\n\n ```\n USERNAME@INTERNAL_IP\n ```\n\n Replace the following:\n - \u003cvar translate=\"no\"\u003eUSERNAME\u003c/var\u003e: your username. If you manage your SSH keys in metadata, the username is what you specified when you [created the SSH key](/compute/docs/connect/create-ssh-keys). For OS Login accounts, the username is [defined in your Google profile](/compute/docs/connect/add-ssh-keys#os-login). For example, `cloudysanfrancisco_example_com` or `cloudysanfrancisco`.\n - \u003cvar translate=\"no\"\u003eINTERNAL_IP\u003c/var\u003e: the internal IP address of the VM.\n6. In the **Category** menu, navigate to **Connection \\\u003e\n SSH \\\u003e Auth**.\n7. In the **Private key file for authentication** field, select the private SSH key file that corresponds to the public key you added to the VM.\n8. Click **Open** to connect to the VM.\n\nTroubleshooting\n\nTo find methods for diagnosing and resolving failed SSH connections, see\n[Troubleshooting SSH](/compute/docs/troubleshooting/troubleshooting-ssh).\n\nWhat's next\n\n- Learn how to [manage access to VMs](/compute/docs/instances/access-overview).\n- Learn how to [transfer files to VMs](/compute/docs/instances/transfer-files).\n- Learn how [SSH connections to Linux VMs](/compute/docs/instances/ssh) work on Compute Engine."]]