Un seul paquet à installer
apt install openssh-server
Le serveur SSH est automatiquement démarré après l'installation du paquet.
La configuration par défaut est très bonne, et il n'est pas conseillé d'y toucher à moins de bien savoir ce que vous faites.
Si vous voulez la personnaliser, il vous faut éditer le fichier /etc/ssh/sshd_config
:
editor /etc/ssh/sshd_config
Les valeurs de configuration par défaut sont souvent présentées commentées (avec un #
en début de ligne).
Comme d'hab', plus d'infos dans le :
man sshd_config
Une fois configuré il vous suffit de relancer SSH, à faire en root :
service ssh restart
Un serveur SSH permet a priori à un utilisateur extérieur de se connecter sur le système. Il y a deux méthodes pour s'authentifier auprès d'un serveur SSH
La deuxième méthode est plus sûre que la première.
Le serveur SSH écoute sur le port 22 du système, qui est accessible depuis le réseau local.
Il peut être intéressant de relire les conseils généraux en matière de sécurité !
Voici quelques options avec lesquelles il ne faut pas faire de blague.
Il ne faut absolument pas autoriser root à se connecter par mot de passe, sauf à s'assurer d'avoir un mot de passe en béton armé2).
Vous pouvez autoriser les connexions à root par paire de clefs publique/privée, c'est le comportement par défaut: PermitRootLogin prohibit-password
ou complètement bloquer toutes les connexions: PermitRootLogin no
Par défaut, la connexion par clefs est autorisée, c'est très bien et reste sans conséquence si vous n'utilisez pas cette possibilité. PubkeyAuthentication yes
Les clefs ssh des utilisateurs sont lues par défaut dans deux fichiers du dossier personnel des utilisateurs : ~/.ssh/authorized_keys
et ~/.ssh/authorized_keys2
(déconseillé).
Vous pouvez forcer l'utilisation unique du premier fichier avec AuthorizedKeysFile .ssh/authorized_keys
.
Si vous voulez interdire la connexion par mot de passe (attention à être sûr de bien pouvoir vous connecter par clef avant…), vous pouvez désactiver cette possibilité avec PasswordAuthentication no
et UsePAM no
Vérifiez que vous n'autorisez pas la connexion aux comptes dont le mot de passe est vide: PermitEmptyPasswords no
Dans un premier temps, laisser “# PasswordAuthentication yes” pour permettre la première connexion depuis ssh client, c'est-à-dire pour permettre la connexion par nom d'utilisateur et mot de passe lorsque aucune clé n'a été générée.
Puis lorsque la génération des clés asymétriques a été faite et que celles-ci ont été exportées et sont opérationnelles (la “passphrase” uniquement est demandée pour la connexion du client ssh au serveur ssh), on peut alors éditer à nouveau /etc/ssh/sshd_config pour mettre PasswordAuthentication no
Plutôt que de laisser possible la connexion à n'importe quel compte utilisateur (à condition d'avoir la clef ou le mot de passe), vous pouvez n'autoriser la connexion que pour certains comptes en spécifiant les noms d'utilisateur:
AllowUsers utilisateur1 utilisateur2
Ou inversement, en interdisant spécifiquement la connexion à certains comptes:
DenyUsers test guest admin root snort apache nobody
Il est possible de spécifier plusieurs utilisateurs ou un masque d'expression régulière, je vous laisse lire la doc pour un paramétrage plus fin.
Dans le même esprit que le paramètre ci-dessus on peut autoriser directement tous les utilisateurs d'un groupe.
AllowGroups mongroupadmin
Si votre serveur SSH est exposé sur internet, il peut être pratique pour limiter le bruit (et dans une moindre mesure, augmenter la sécurité), de changer le port d'écoute de celui-ci.
On peut par exemple changer le port 22 (c'est le port par défaut du service SSH) pour le port 10010 avec la directive Port 10010
Il est important de regarder les logs de temps en temps. Les tentatives de connections infructueuses sont consignées dans /var/log/auth.log
.
grep Invalid /var/log/auth.log
Un outil comme logcheck peut être utile pour envoyer systématiquement les logs par email.
Rediriger un port (22 par exemple) de la freebox/livebox/whateverbox vers le port ssh de votre machine pour vous connecter chez vous depuis l'extérieur.
fail2ban est un utilitaire permettant de bannir automatiquement (pendant une durée configurable) les ip ayant échoué plusieurs fois d'affilée à se connecter.
apt install fail2ban
Pour limiter SSH au partage de fichiers, voir Configuration d'OpenSSH comme serveur SFTP