简体   繁体   中英

SSH to Amazon EC2 instance using PuTTY in Windows

I am a newbie to Amazon web services, was trying to launch an Amazon instance and SSH to it using putty from windows. These are the steps I followed:

  1. Created a key pair.

  2. Added a security group rule for SSH and HTTP.

  3. Launched and instance of EC2 using the above key pair and security group.

  4. Using PuTTYgen converted the *.pem file to *.ppk

  5. Using putty tried connecting to the public DNS of the instance and provided the *.ppk file.

I logged in using 'root' and 'ec2-user', and created the PPK file using SSH1 and SSH2, for all these attempts I get the following error in putty,

"Server refused our key"

Can you guys please help, any suggestions would be greatly appreciated.

我假设 OP 已经解决了这个问题或以其他方式继续前进,但答案是使用ubuntu作为用户(如果服务器是 ubuntu)。

1) Make sure you have port 22 (SSH) opened in Security Group of EC2 Instance.

2) Try connecting with Elastic IP instead of public DNS name.

I hope you have followed these steps Connecting EC2 from a Windows Machine Using PuTTY

Another situation where I got the "Server refused our key" error when using putty, from windows, to ssh to an EC2 instance running ubuntu:

The private key was wrongly converted from .pem to .ppk.

puttygen has two options for "converting keys".

  1. Load your .pem file into puttygen using the File->Load Private Key option and then save as .ppk file using the Save Private Key Button.
  2. DO NOT use the menu option Conversions->Import Key to load the .pem file generated by EC2.

    See the puttygen screenshots below, with the two menu options marked.

使用 puttygen 更正菜单选项 使用 puttygen 拧紧菜单选项

Check the username, it should be "ubuntu" for your machine. Check if traffic is enabled on port 22 in Security group. Check if you are using the correct url ie ubuntu@public/elasticip

Maybe worth of checking one more thing. Go to AWS console, right mouse click on the instance and choose "Connect...". It will show you the DNS name that you want to use. If you restarted that instance at some point, that DNS name could have changed.

I had a similar problem when I tried to connect an instance created automatically by the Elastic Beanstalk service (EBS). But, once I linked my existing key name to the EBS (under Environment Details -> Edit Configuration -> Server Tab -> Existing Key Pair), I was able to login with 'ec2-user' and my existing key file (converted to .ppk) with putty.

This, however, terminates the running instance and rebuilds a new instance with access through the key pair named above.

Just in case it helps anyone else, I encountered this error after changing the permissions on the home folder within my instance. I was testing something and had executed chmod -R 777 on my home folder. As soon as this had occurred, once I had logged out I was effectively locked out.

You won't face this error if you SSH AWS directly using ".pem" file instead of converted ".ppk" file.

1) Use Git Bash instead of putty. Since you can run all the Linux commands in Git Bash. By installing Git you get to access Git Bash Terminal

2) Right click from the folder where you have ".pem" and select "Git Bash Here".

3) Your key must not be publicly viewable for SSH to work. So run "chmod 400 pemfile.pem".

4) Connect to your instance using its Public DNS - "ssh -i "pemfile.pem" ec2-user@ec2-xxxx.us-west-1.compute.amazonaws.com"

5) Make sure to whitelist your Network IP for SSH in your_instance->security_group->inbound_rules

I assume you're following this guide , and connecting using the instructions on the subsequent page . Verify a couple of things:

  1. You converted the key correctly, eg selected the right .pem file, saved as private key, 1024-bit SSH-2 RSA
  2. The Auth settings (step 4 in the connection tutorial) are correct

Try an alternative SSH client, like Poderosa . It accepts pem files, so you will not need to convert the key file.

I was having the same trouble (and took the same steps) until I changed the user name to 'admin' for the debian AMI I was using.

You should lookup the user name ofthe AMI you are using. The debian AMI is documented here http://wiki.debian.org/Cloud/AmazonEC2Image/Squeeze

I have had this same problem. The AMI you are using is the one that is also used by the "Cloud Formation" templating solution.

In the end I gave up with that, and created a Red Hat instance. I was then able to connect by SSH fine using the user root .

The instructions here: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/putty.html work fine using a Red Hat instance but not using an Amazon Linux instance. I assume they have some username that I didn't think to try (root, ec2-user, and many other obvious ones, all were refused)

Hope that helps someone!

我使用 Debain AMI 并尝试使用 ec2-user、root 但正确的登录名是“admin”。

I was getting the same error when I tried to create a new key pair and tried to use that new pem/ppk file. I noticed that the Key Pair Name field on the instance was still the old one and in poking around. Apparently, you can't change a key pair. So I went back to the original key pair. Fortunately, I didn't delete anything so this was easy enough.

如果您已有密钥对,请按照以下步骤操作: 使用 PuTTYgen 将 *.pem 转换为 *.ppk(加载 pem 文件密钥,然后保存 ppk)将 ppk auth 密钥文件添加到 Putty SSH>Auth 选项输入“主机名(或 IP 地址) )" 字段:ubuntu@your-ip-address-of-ubuntu-ec2-host))

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM