Have you ever launched an EC2 instance and don’t know how to log in to your brand-new instance? It may sound difficult for a beginner, but it’s simple. I will help connect to an EC2 instance using SSH, whether you are using Linux or macOS.
- What do you Need to Connect to an EC2 Instance with SSH in Linux?
- How to Connect to an EC2 Instance using SSH in Linux and macOS
- Linux & MacOS Troubleshooting
- Common Questions about Connecting to EC2 Instances Using SSH
What do you Need to Connect to an EC2 Instance with SSH in Linux?
- SSH Key (.pem file) provided by Amazon. This SSH key is provided by AWS when you launch the instance.
- Public IP address: IP address assigned to your EC2 instance.
- Username. The username depends on the Linux distro you just launched. Usually, these are the usernames for the most common distributions:
- Ubuntu: ubuntu
- Amazon Linux: ec2-user
- Centos: root
How to Connect to an EC2 Instance using SSH in Linux and macOS
1. Open your terminal and change the directory with the command cd, where you downloaded your pem file. In this demonstration, pem file is stored in the downloads folder.
cd Downloads
This is the explanation of the previous command:
data:image/s3,"s3://crabby-images/c6b0a/c6b0a69cb0872a21124e39db0a17a32d92a5b8c6" alt="screenshot of command in aws terminal"
2. Locate the required values in order to connect to your EC2 Instance:
- SSH Key: This key is usually located in the Downloads folder when the instance was launched. The name was provided during the instance launch process. In this example, the key name is called “ec2_tuturial” with the extension .pem. In the CLI , you can find it like this:
data:image/s3,"s3://crabby-images/a3d0e/a3d0efb123879e41b75fcda6e8bdd17079a2201e" alt="screenshot of command in aws terminal for SSH key"
In the macOS Finder
data:image/s3,"s3://crabby-images/b94de/b94de1eaff20d9dc40eff523fe7f2d1a66659f8f" alt="screenshot of macOs for ec2 public IP Address"
EC2 Public IP Address: AWS assigned a public IP address to the instance, if you’re unable to locate it, go to the EC2 dashboard in the AWS console and go to the instance launched, then go Details and copy the Public IPv4 address, in this example, the value is 3.208.71.105
data:image/s3,"s3://crabby-images/2dbb9/2dbb98163bc95313442af01cde9254502dce3009" alt="screenshot of macOs for ec2 public IP Address"
OS User: Depending on which OS you used on the instance, the default OS user may vary, for Ubuntu distributions use “ubuntu”, for Amazon Linux OS images, use “ec2-user” and for other Linux distributions like CentOS use “root”.
3. Type the SSH command with this structure:
ssh -i instance_key_file.pem
instance_os_user@instance_public_ip_address
For example, using the values obtained in the previous step, the command would look like this:
ssh -i ec2_tutorial.pem [email protected]
This is the explanation of the SSH command:
- ssh: Command to use SSH protocol
- -i: Flag that specifies an alternate identification file to use for public key authentication.
4. Press enter, you will be prompted to add the host to your known_hosts file. Type yes and press enter. This will help to recognize the host each time you’re trying to connect to your instance..
data:image/s3,"s3://crabby-images/388ef/388ef11c50089e4bc15c6f7d76072d1e0410f64c" alt="screenshot of macOs for ec2 public IP Address to connect to your instance"
5. And that’s it! Now you’re logged in on your AWS instance
data:image/s3,"s3://crabby-images/d7475/d7475a4a01ae4fe8a0ef6fcd89584d4ec1d8377a" alt="screenshot of macOs for logged in on your AWS instance"
data:image/s3,"s3://crabby-images/e2313/e23139e51e954d28e5cbf754594746f6690816b2" alt="deploy nodejs app to aws"
Linux & macOS Troubleshooting
If you struggled to connect to your brand new instance, it is probably that you found some errors, here’s two common errors and how to fix them
data:image/s3,"s3://crabby-images/b77a4/b77a41cad21a9818999fadd46b78c800f093d93f" alt="linux and macOS Troubleshooting screenshot"
This means that the key downloaded does not have proper permissions , this is fixable by running this command:
chmod 400 key_file.pem
- Replace the “key_file.pem” with your key and run it
data:image/s3,"s3://crabby-images/48b64/48b64be8c0c35d6fac5323e5bd774900f91356c8" alt="linux and macOS Troubleshooting screenshot key_file.pem” with your key and run it"
Then run the SSH command again and you should be in!
2. Connecting is timing out
This error usually means that the port assigned to the SSH protocol, port number 22, is not allowed to receive incoming connections. Let’s fix this error by adding our Public IP address to the Instance
3. First, go the AWS console, go to the EC2 Service
data:image/s3,"s3://crabby-images/359b6/359b66d842480348640e778339f9957efec2f3df" alt="screen shoot AWS console, go to the EC2 Service"
data:image/s3,"s3://crabby-images/866f3/866f3dac81042d6fda958c64912f265b9df5189f" alt="screen shoot AWS console, go to the EC2 Service instances"
4. Go to the Security groups and select the security group attached to the instance, usually AWS names the security groups as “launch-wizard-number” by default.
data:image/s3,"s3://crabby-images/96930/96930eb386d2ea8070e158e58f4cdbb2b7e8fe4d" alt="screen shoot Security groups in aws"
5. Go to the inbound rules, and click on Edit inbound rules
data:image/s3,"s3://crabby-images/6004d/6004dc3b59fdc152b5224626446ece37e7f96936" alt="screen shot inbound rules aws macOS"
6. Click Add rule
data:image/s3,"s3://crabby-images/5b066/5b066774a1126f5d5a2292ede5a45e74f25bf846" alt="screen shot of edit inbound rules"
7. Type SSH and select SSH Type, by default Protocol and port will be automatically assigned.
data:image/s3,"s3://crabby-images/124ab/124ab4d72cef156801e6e211d55d13644eda323f" alt="screen shoot inbound rules"
8. In the source column, select “My IP”, this will add your Public IP to the security group
data:image/s3,"s3://crabby-images/5f3db/5f3db902d4563e66718ec41b0fdafc9186894a1d" alt="screen shoot click to select custom"
9. Finally, click on Save rules
data:image/s3,"s3://crabby-images/ecd9a/ecd9a93355f10c6a03df3293be59971743546cb3" alt="screen shot to save rules"
You might also like: What is AWS ECS? – Run Docker in Production and AWS Security Tools
This blog is also available on our DZone profile
Common Questions about Connecting to EC2 Instances Using SSH
EC2 (Elastic Cloud Compute) is a service where you can create servers to launch your websites or applications. One of the first things you will find when you create an EC2 instance is the instance type/size. Learn more about creating and choosing the best EC2 instance for your project here.
Since many other providers on the network can host your app, we choose Amazon EC2 because it offers a lot of possibilities. You can start with a small instance, then, when you get more traffic, grow it up to a bigger option, making EC2 more flexible and adaptable than other technologies to host your application.
– High availability level.
– High-reliability level.
– Scalable in memory space and server size.
– The hard disk space is independent of the instance size, so it can be set according to your requirements and increased using the AWS service EBS (Elastic Block Store).
– It offers “double” security since, in addition to the default firewall, AWS Security Groups restrict the ports you prefer.
Secure Socket Shell (SSH) enables public-key-based authentication and facilitates encrypted connections between two endpoints in a network. Generating SSH keys to access containers and servers is highly recommended for securing your IT resources, and it is one of many DevOps security best practices.
It’s commonly used to connect to EC2 instances on AWS to manage servers, transfer files, and perform administrative tasks because it provides a versatile and efficient way to remotely manage EC2 instances, configure servers, execute commands, and transfer files, which are essential tasks for maintaining cloud infrastructure on AWS
Check for common issues such as incorrect security group settings, missing SSH key pair, wrong instance state, or incorrect private key permissions. Ensure that the EC2 instance’s firewall rules allow SSH access.
You can create and manage multiple SSH key pairs in AWS, associating each one with a specific EC2 instance. You can also use the AWS Systems Manager Session Manager for more secure access without needing an SSH key