How To Set Up SSH With Public-Key Authentication On Debian Etch

Preliminary Notes

This mini-howto explains how to set up an SSH server on Debian Etch with public-key authorization (and optionally with disabled password logins). SSH is a great tool to control Linux-based computers remotely. It's safe and secure.

There's no warranty that it'll work for you. All of these settings are applicable for Debian and -like systems! There may be slightly changes on other systems as well.


Installing SSH On The Server

First, we install the SSH on our server. We can do that with this command: (Note that you must be root to do that!)

apt-get install ssh


Preparations On Our Client (Desktop) System

Second, we take some preparations on our desktop machine. This PC will be used to connect the server. So, the SSH-server has been installed on a different machine. On your desktop machine, we install the ssh client (which we use to connect the server). Note that installing programs requires root privilege! If you're not logged in as root, please log in! (su root then type your password.) Then install the client:

apt-get install openssh-client

Switch back to your normal user (not root, respectively). Then type these commands in order:

mkdir ~/.ssh
chmod 700 ~/.ssh
cd ~/.ssh

We generate our key-pair, a public-key and a private-key. The public-key will be placed on the server, and you will log in with your private-key. When asked, type your passphrase (it'll be needed for future logins, so remember it!):

ssh-keygen -t rsa -C "A comment... usually an email is enough here..."

Then we copy the public key (which we've generated just before) to our (remote) server. The remoteuser should not be root! Choose the default non-root user as remoteuser. (Note the colon at the end of the line! It's important.)

scp -p remoteuser@remotehost:

Then we log in with SSH, and we copy the public key to its right place:

ssh remoteuser@remotehost
mkdir ~/.ssh
chmod 700 ~/.ssh
cat >> ~/.ssh/authorized_keys
chmod 600 ~/.ssh/authorized_keys
mv ~/.ssh

We have to delete the public key on the desktop, because otherwise the SSH client doesn't allow us to log in to the server. So, type this command:


And then we log back:

ssh remoteuser@remotehost

If we've done everything precisely as detailed above, then you'll be asked for the passphrase. Type it, then you are in and have a fairly safe SSH-environment!


Disabling Password Authentication

Disabling it is a good way to have a safer SSH-installation. Then you can log in only with a key-pair, so be careful not to lose it! It's purely optional but safe to activate! But before doing it, please make sure that key-based authentication is working out-of-the-box. Sit down in front the server (so don't log in remotely as we have to restart the SSH later...) and type these commands manually as root:

cd /etc/ssh
cp sshd_config sshd_config.orig
nano sshd_config

You will have the nano text-editor on screen open with the main SSH configuration file. Change these lines (don't bother if any of these lines have a '#' mark at the beginning; if they have, just delete the hashmark as well):

PermitRootLogin		yes
PasswordAuthentication	yes
UsePAM			yes

To these:

PermitRootLogin		no
PasswordAuthentication	no
UsePAM			no

Then save the file with Ctrl + O , and restart the SSH server:

/etc/init.d/ssh restart

Be careful: if you disable password authentication, then you won't be able to log in with passwords! Only key-based authentication will be available!

Share this page:

Suggested articles

7 Comment(s)

Add comment



here are a couple of additional tips:

you don't need to create the .ssh direrectory yourself, ssh-keygen will do that for you if its unable to find it. 

And to copy keys: 

ssh-copy-id -i .ssh/id_rsa

You can also use ssh-copy-id to copy over your key to the remote host as well.  If no .ssh  directory or authorized_keys file exists, it creates them or if they do, it appends the key to the end of the authorized key file.



Thanks for replying.

I created the ".ssh" directory, because later we modify the privileges of the directory. You're right we could do that we generate the key and then we chmod the ".ssh" dir, but I think it's simplier...

By the way, I didn't know about ssh-copy-id command; it's really a great tool, thanks for notifying me about that.


Shouldn't it be like...?:

ssh-copy-id -i .ssh/

I'll guess you want to keep your private key for yourself.

From: Merljin

Thanks for this HOWTO manual - it`s very useful.


From: Gary Dale

I just followed it almost verbatim (I use aptitude instead of apt-get) on Debian/Squeeze and it worked perfectly. Presumably that means it also works on Lenny.

 Thanks for the howto!

From: Ferdinand Gruber

I cannot understand the necessity of this command:

   mv ~/.ssh

Why do you move the public key into ~/.ssh on the remote server? It exists already in the file ~/.ssh/authoreized_keys

From: deved

HelloI am having trouble using the system. When I log on I should have ubuntu and we have to put public key so instead of passwordI want to know how to log on change where user name Root and speak the mystery of normal is not so public key