Troubleshooting the SSH Connection
If you're unable to connect to a compute instance using SSH, review the following troubleshooting error messages and suggestions to resolve the issue.
If this is your first time creating an instance, for a guided tutorial consider one the following:
If this is your first time creating an instance, we recommend creating a Virtual Cloud Network (VCN) first. You can use the "Start VCN Wizard" workflow and select the "Create VCN with Internet Connectivity" option. The workflow creates a VCN which automatically configures both a public and a private subnet along with any required gateways and route rules. In addition, the workflow provides an option to configure IPv6. For details on running the workflow see: Virtual Networking Quickstart.
SSH Error: connect to host w.x.y.z port 22: Operation timed out
The error means SSH can't connect to the host at the IP address specified. Check the following scenarios to resolve the issue.
Ensure the System has Internet Access
- Ensure the Environment the SSH command is executing and has Internet Access
-
- Windows: Open a command prompt window.
- MacOS/Linux: Open a terminal window.
- Ping a well known host like google.com or amazon.com.
- If the ping command is successful, continue to the next option.
- Ping Failed
-
Your SSH environment might not have access to the internet. If you unsure about your organizations firewall settings for internet access, consider using OCI Cloud Shell to SSH to the instance. See the OCI Cloud Shell Section on this page for details.
Check the OCI Settings
Next, check the OCI settings to verify your configuration.
- Open the Instance Details
-
- Log into the OCI Console.
- Open the navigation menu and select Compute. Under Compute, select Instances.
- Select the instance you are interested in. The instance details page is displayed.
- Check the following Settings
-
- Ensure the instance is running and is not stopped.
- Ensure the instance has a public IP address.
- Look at the Instance access section. If a public IP address is assigned, the address will be labeled: Public access IP address:
- If the Instance Access section is empty, then no public IP address is assigned.
- If you have a public address, ensure you are using the correct IP address in your SSH command.
- If you don't have a public IP address, check your VCN subnet.
- If you're on a private subnet, you can't connect to your instance from the Internet. See the Using a Private Subnet section.
- If you created an instance on a public subnet, but didn't assign a public IP address at instance creation, you can still assign the address, see: Assigning an Ephemeral Public IP to an Existing Primary Private IP.
- After setting the IP address, restart the instance and try using SSH to connect to your instance.
The Instance has a Public IP Address on a Public Subnet and I still Can't Connect
If you are new to OCI, the following troubleshooting steps are more advanced. To speed things up, consider setting up a new VCN and a new Compute instance as described in the following tips.
If this is your first time creating an instance, for a guided tutorial consider one the following:
If this is your first time creating an instance, we recommend creating a Virtual Cloud Network (VCN) first. You can use the "Start VCN Wizard" workflow and select the "Create VCN with Internet Connectivity" option. The workflow creates a VCN which automatically configures both a public and a private subnet along with any required gateways and route rules. In addition, the workflow provides an option to configure IPv6. For details on running the workflow see: Virtual Networking Quickstart.
- Open the Instance Details
-
- Log into the OCI Console.
- Open the navigation menu and select Compute. Under Compute, select Instances.
- Select the instance you are interested in. The instance details page is displayed.
- Review the VCN Configuration
-
- Click the VCN assigned to this instance.
- Ensure at least one Internet Gateway is available in the Internet Gateways resource.
- If no Internet Gateway is assigned, go to the next section.
- If an Internet Gateway is assigned, ensure your public subnet has a route rule assigned for the gateway.
- Under the Subnets resource, select your public subnet.
- Under Subnet Information click the Route table link.
- Ensure there is a static route with a destination of
0.0.0.0/0
. - If the route entry is missing, go to the next section.
- My Public Subnet isn't Properly Configured
-
If it appears your public subnet isn't configured properly, you have two options to reconfigure your subnet.
(1) Use the Compute Quick Action.
From the instance details page:
- In the Resources list, select Quick Actions.
- Click Connect on the Connect public subnet to internet quick action.
- Follow the workflow to connect your instance.
(2) Manually create a public subnet.
- Use the Scenario A: A Public Subnet document to walk through the steps to setup and configure a new public subnet.
- Create a new Compute instance in the new public subnet.
- Check Security Lists
-
If you're continuing to have issues, ensure your security lists allow traffic on port 22. See Security Lists for details.
- Advanced Troubleshooting
-
If you're an advanced user, you can use the Network Path Analyzer to further troubleshoot the network connection. See Network Path Analyzer for details.
SSH: Connect to host w.x.y.z port 22: Connection refused
This error message is caused because a host is listening at the target address, but you can't connect to port 22.
Use Netcat(nc) to verify that SSH is Running
Linux or MacOS
In a terminal window, run the following command:
nc <public ip> 22
-
If the command returns a message similar to:
SSH-2.0-OpenSSH_9.4
You successfully connected to the instance and verified SSH is running. Double check the IP address in your SSH command, ensure it is correct.
If the command returns nothing:
- Check the public IP address on the instance detail page to ensure you are using the correct address.
- Double check the IP address used in the command, ensure it is correct.
Otherwise, continue to the next section.
Windows
In a PowerShell window, run the following command:
tnc <public ip> -p 22
-
If the command returns a message similar to:
ComputerName : <public ip> RemoteAddress : <public ip> RemotePort : 22 InterfaceAlias : Ethernet SourceAddress : <source ip> TcpTestSucceeded : True
You successfully connected to the instance and verified SSH is running. Double check the IP address in the SSH command, ensure it is correct.
- If the command returns:
WARNING: TCP connect to (<public ip>) failed
- Check the public IP address on the instance detail page to ensure you're using the correct address.
- Double check the IP address used in the command, ensure it is correct.
Otherwise, continue troubleshooting with the next section.
SSH is not Running
- Check that the instance is on a public subnet.
- If the instance is on a private subnet, you can't connect to the instance directly. See the Using a Private Subnet section.
- Ensure the security lists are configured to allow connections to port 22. See Security Lists for details.
- Reboot the instance to restart the SSH daemon.
- Advanced: If you're using a custom image and need to start or install the SSH service, use the Serial Console to connect to the instance.
<user-name>@w.x.y.z: Permission denied (publickey,gssapi-keyex,gssapi-with-mic)
This error message indicates SSH is connecting to the SSH service host, but there is an issue with the SSH command.
Check for the following Issues with your SSH Command
- Double check all the command line options for SSH. Any incorrect option might cause this error message.
- The following is an example of a correctly formatted SSH command to connect to Oracle Linux.
ssh -i <my-private-key-file> opc@x.x.x.x
- The following is an example of a correctly formatted SSH command to connect to Oracle Linux.
- Ensure you're using the correct user name for the instance:
- For Oracle Linux or other Red Hat compatible OSes, use
opc
. - For Ubuntu Linux, use
ubuntu
.
- For Oracle Linux or other Red Hat compatible OSes, use
- Ensure you are using the correct private key. Using the wrong private key file will result in this error message.
- Ensure you're in the directory containing the key.
- Alternatively, ensure the path to the private key is correct.
- I lost my private key.
- Make a new instance and download the new public and private keys.
- Make a new public and private key set. Create a new instance.
Using Cloud Shell to connect to an OCI Instance
OCI Cloud Shell is a web browser-based terminal accessible from the OCI Console. Cloud Shell is free to use (within monthly tenancy limits), and provides access to a Linux shell, with a pre-authenticated OCI CLI, a pre-authenticated Ansible installation, and other useful tools.
If you are having connectivity issues with your instance, Cloud Shell is an effective option for connecting with SSH. Since Cloud Shell is browser based, it eliminates any potential connectivity issues due to laptop or corporate firewall settings. This section links you to the information about the ways you can use Cloud Shell.
-
For information on Cloud Shell, see Cloud Shell.
-
For information on how to access Cloud Shell, see Using Cloud Shell.
- For information on how to connect a Cloud Shell session to a private network, see Cloud Shell Private Networking.
Using a Private Subnet
If your Compute instance is on a private subnet, there are generally two scenarios.
- (1) The Instance is on a Private Subnet but should be on a Public Subnet
-
To have the instance on a public subnet you have the following options.
- Create a new instance in a public subnet in the current VCN. Terminate the old instance.
- Create a new public subnet in the current VCN. Create a new instance in the new public subnet. Terminate the old instance.
- Create a new VCN with a public subnet and then create a new instance in the public subnet. Terminate the old instance.
Tip
If this is your first time creating an instance, for a guided tutorial consider one the following:Tip
If this is your first time creating an instance, we recommend creating a Virtual Cloud Network (VCN) first. You can use the "Start VCN Wizard" workflow and select the "Create VCN with Internet Connectivity" option. The workflow creates a VCN which automatically configures both a public and a private subnet along with any required gateways and route rules. In addition, the workflow provides an option to configure IPv6. For details on running the workflow see: Virtual Networking Quickstart. - (2) The Instance is intentionally on a Private Subnet
-
When the Compute instance is on a private subnet, you can connect to it using:
- Cloud Shell: See the OCI Cloud Shell Section on this page for details.
- Bastion provides restricted and time-limited access to target resources that don't have public endpoints. See the Bastion Overview for more details.
Additional Connection and Instance Troubleshooting Options
The focus of this page is using the SSH command to connect to an instance. Here are other tools available to troubleshoot Compute instances.
Troubleshooting with the Serial Console
Using an OCI console connection, you can use the instance's serial console to connect to the instance. This allows you to remotely troubleshoot and configure an instance. For more information, see Troubleshooting Instances Using Instance Console Connections.
- Interrupt the boot process to boot into maintenance mode.
- In maintenance mode, add or reset the SSH key for the
opc
user.
Observe Instance Health
On the instance details page, you can observe metrics related to the instance including the instance's health. The oci_compute_instance_health
metric lets you monitor whether a VM instance is unresponsive. Compute sends an Address Resolution Protocol (ARP) request to the instance's virtual network interface card (VNIC). If the ARP ping fails, the metric shows that the instance is unresponsive.
To use the metric, select oci_compute_instance_health
from the Metric namespace control on the details page. For more information, see: Compute Instance Health Metrics.
Other Compute Troubleshooting Sections
In addition to SSH, the following troubleshooting topics are also available.