I need to run ssh-add <key>
everytime I need to ssh into a webserver. Is there a way to add the ID permanently, so I dont have to keep adding the identities on each login?
EDIT: The key is a pem file, that I have downloaded from a cloud service.
I need to run ssh-add <key>
everytime I need to ssh into a webserver. Is there a way to add the ID permanently, so I dont have to keep adding the identities on each login?
EDIT: The key is a pem file, that I have downloaded from a cloud service.
Generate your key like normal:
ssh-keygen
, then place that key to the remote server withssh-copy-id
, which will sync it to the remote server's accepted keys.It will prompt for your password then perform all the steps necessary to link your
.pub
key with the remote SSH server.By default it will copy all your .pub keys to the remote server. If you just created your key with
ssh-keygen
then this isn't a problem (because you only have one!). However, if you have multiple keys you can copy just a specific key with the-i
flag.Replacing
key_name.pub
with the name of the key.put this in your
~/.bashrc
You can generate a ssh key with the command:
Then you can copy your key to the server with:
Now you can automatically log in your webserver
If your key is password-less and named as one of the files ssh will try to look for when identifying (
~/.ssh/id_dsa
or~/.ssh/id_rsa
), you shouldn't have to add it to your agent.BUT. If there's the slightest possibility of those files being stolen, you would have just allowed anyone to access the servers on which you are using this identity. In short, pwned.
IMHO, password-less private keys are a bad practice, and should be used only on environments where
~/.ssh/authorized_keys
is very restrictive.Write a short shell script which will run ssh-add and then connect such as the following:
You can then ssh into your host with one command.
For AWS, download the pem key, and run:
That worked for me, ubuntu 18.04. Source, Nothing else was needed.
NB: However, it is important to set the permissions to 400 before doing this.
If not you will get an error:
Are you talking about Amazon Cloud? In your ~/.bashrc, create environment variables: