Voir sur SSH Avancé pour les autres usages.
SSH est un protocole réseau permettant d'établir une communication chiffrée entre deux machines. Il est notamment utilisé pour se connecter à distance à un serveur SSH, y exécuter des commandes ou transférer des fichiers de manière sécurisée.
Par défaut, un serveur SSH écoute sur le port TCP standard 22. Un programme client SSH est généralement utilisé pour établir des connexions avec le serveur qui exécute un démon sshd.
SSH remplace de manière sécurisée :
Les usages de SSH sont entre autre :
OpenSSH est la solution la plus utilisée pour mettre en place une communication SSH via un ensemble d'outils libres dont certains sont installés par défaut sur Ubuntu. Comme son nom l'indique, OpenSSH est développé dans le cadre du projet OpenBSD. C'est cette solution que nous traiterons sur cette page.
Si vous voulez accéder à un ordinateur (votre ordinateur personnel, votre serveur local, un serveur distant dont vous effectuez l'administration, etc.). Vous devez installer openssh-server sur la machine à joindre en SSH, cette machine sera le "serveur" SSH.
La partie cliente est fournie par le paquet openssh-client, qui est installé par défaut sous Ubuntu.
Vous pouvez vérifier ce qui est déjà installé en tapant ces commandes :
ssh -V
qui retourne une ligne du type :
OpenSSH_8.2p1 Ubuntu-4ubuntu0.5, OpenSSL 1.1.1f 31 Mar 2020
et aussi la commande suivante pour connaître la version de la bibliothèque ssl:
dpkg -l libssl*
Installez le paquet openssh-server sur votre poste.
Le serveur SSH fonctionne en tant que service lancé automatiquement au démarrage de la machine.
Il est possible notamment de :
Vous trouverez en fin de cette page plus d'information sur la Configuration du serveur SSH, peu sécurisée par défaut.
sudo systemctl stop ssh
sudo systemctl restart ssh
Sur le poste client openssh-client est déjà installé par défaut. Dans le cas contraire Installez le paquet openssh-client.
Si vous devez prendre le contrôle depuis un poste équipé de Windows vous pouvez installer PuTTY qui est disponible sous licence MIT (une licence libre comparable à la licence BSD), openssh est installable dans le shell Windows depuis la version 1809 https://docs.microsoft.com/fr-fr/windows-server/administration/openssh/openssh_install_firstuse.
Si vous voulez établir une connexion SSH depuis un smartphone Blackberry®, vous pouvez installer bbssh, qui est sous licence libre GPLv2, les sources sont fournies.
Il existe aussi des clients SSH pour Android (connectbot), J2ME (téléphones portables Java), iPhone, et quasiment tous les systèmes d'exploitation trouvables.
Pour ouvrir une session distant ayant un serveur SSH, vous devez écrire quelque chose comme ceci :
ssh <nom_utilisateur>@<ipaddress> -p <num_port>
Exemple :
ssh phyrex@192.168.23.42 -p 12345
L'option -p <num_port> qui précise le port utilisé par le serveur est facultative. Si rien n'est précisé, c'est le port 22 qui sera utilisé par défaut (protocole TCP).
Pour se connecter avec SSH en IPV6 depuis un terminal, écrire sans crochet :
ssh -6 <nom_utilisateur>@<adresse ipv6>
Exemple : par exemple pour un lien Internet :
ssh -6 alfred@2a01:e35:2431::2e57
ssh utilisateur@nom_machine
à partir du moment où celui-ci est résolu en adresse IP par votre machine.
Cela peut se faire sur le réseau local par le fichier /etc/hosts (ou bien, pour passer par une interface graphique, en tapant dans un terminal
network-admin
puis en allant dans l'onglet "Hôtes", continuer en déverrouillant les droits administration en cliquant sur le cadenas, et enfin, en cliquant sur le bouton "ajouter"), éventuellement distribué d'un serveur vers les clients locaux au travers de NIS, ou bien par un service de DNS si vous accédez à une machine distante (serveur loué) pour lequel vous avez enregistré un nom de domaine.
Remmina est actuellement l'outil le plus complet pour la gestion des bureaux à distance.
La commande ssh offre une fonctionnalité intéressante: la possibilité d'exécuter des applications X-Window à distance, ce qui est bien pratique pour travailler à distance, partager une machine ou simplement effectuer des tâches d'administration.
Il suffit de passer l'option -X à ssh :
ssh -X nomtilisateur@Ipserver
Et on peut lancer :
nomUtilisateur@Ipserver$ xeyes
là, l’œil de Moscou vous regarde depuis votre écran local !
N.B. : pour que cet exemple fonctionne il faut que le paquet x11-apps qui fournit xeyes soit installé sur le serveur.
Pour copier un fichier à partir d'un ordinateur sur un autre avec SSH, vous devrez utiliser la commande scp ou rcp. Cela ressemblera à ceci :
scp <fichier> <username>@<ipaddressDistant>:<DestinationDirectory>
et en IPv6
scp -6 <élément> <nom>@[addresse ipv6]:<destination>
Pour un fichier:
scp fichier.txt hornbeck@192.168.1.103:/home/hornbeck
et en IPv6
scp -6 fichier.txt albertine@[2a01:e35:2431::2a34]:/home/albertine
Pour un répertoire:
scp -r répertoire hornbeck@192.168.1.103:/home/hornbeck/
et en IPv6
scp -6r répertoire/ albertine@[2a01:e35:2431::2a34]:/home/albertine
Vous pouvez aussi bien copier des fichiers à partir des ordinateurs à distance sur votre disque local :
scp hornbeck@192.168.1.103:/home/hornbeck/urls.txt .
Ici, le point . à la fin de commande indique de copier le fichier dans le répertoire courant.
$ scp utilisateur@12.345.678.90:"le\ fichier" . $ scp utilisateur@12.345.678.90:'"le fichier"' . # Notez les simples ' ET doubles " guillemets ' "
$ fichier="le fichier" #ou $ fichier=le\ fichier $ scp utilisateur@12.345.678.90:"'$fichier'" . $ fichier="le\ fichier" $ scp utilisateur@12.345.678.90:"$fichier" .
de local vers distant c'est différent
$ scp le\ fichier utilisateur@12.345.678.90: le fichier 100% 0 0.0KB/s 00:00 $ scp "le fichier" utilisateur@12.345.678.90: le fichier 100% 0 0.0KB/s 00:00
$ fichier="le fichier" # ou $ fichier=le\ fichier $ scp "$fichier" utilisateur@12.345.678.90: le fichier 100% 0 0.0KB/s 00:00
cf : https://forum.ubuntu-fr.org/viewtopic.php?pid=21768296#p21768296
Vous pouvez aussi le renommer en le copiant (« mon.txt ») sur le disque local (toujours dans le répertoire courant):
scp hornbeck@192.168.1.103:/home/hornbeck/urls.txt ./mon.txt
Vous pouvez très bien copier un fichier d'un ordinateur vers un autre tout en étant sur un troisième ordinateur :
scp nom@ordi1:chemin/fichier nom@ordi2:chemin/fichier
Dans le cas où le port SSH du serveur ne serait pas le port par défaut (22), il faut indiquer le port distant à utiliser :
scp -P port fichier.txt hornbeck@192.168.1.103:/home/hornbeck
Vous pouvez sécuriser un répertoire en le dupliquant à travers le réseau en utilisant la commande rsync.
Exemple1: Pour transférer le home d'un utilisateur a hébergé dans la machine b dont l'adresse IP est enregistrée dans le fichier /etc/hosts en excluant quelques fichiers avec un résultat à mettre dans le répertoire /MAISON qui sera automatiquement créé.
sudo rsync -ahv --progress --stats --exclude={'.*','persistence.*'} a@b:/home/a /MAISON 2>err.log cat err.log
SFTP est une autre méthode pour accéder à ses fichiers via SSH. Au lieu de travailler fichier par fichier, il est possible grâce à cette méthode de naviguer dans ses fichiers depuis un client SFTP. Ce type d'accès est possible grâce à des outils comme Nautilus, Konqueror, Dolphin, WinSCP, Pcmanfm ou FileZilla, dont la mise en œuvre est décrite dans les sections suivantes.
En utilisant le gestionnaire de fichiers Nautilus, vous pouvez également accéder aux emplacements à distance par l'intermédiaire de SSH pour passer en revue, modifier et copier des fichiers.
Ouvrez Nautilus, puis dans la fenêtre emplacement (Ctrl + L), entrez l'URL suivante en remplaçant nom_utilisateur
, hostname
et port
en conséquence :
ssh://nom_utilisateur@hostname:port
La copie de fichier se fait avec le glisser-déposer dans la fenêtre de Nautilus comme sur votre système de fichiers local.
Pour accéder directement à un répertoire donné (pratique avec l'utilisation des signets), il suffit de rajouter le chemin en fin d'URL :
ssh://username@hostname:port/le/chemin/voulu/
Il est également possible d'y avoir accès dans Nautilus par le menu Fichiers → Autres emplacements → Se connecter à un serveur… et choisir le Type de service
« ssh ».
Le principe est similaire à celui utilisé par Nautilus, à l'exception du nom de protocole : sftp
.
Dans la barre d'adresse, tapez :
sftp://<nom_utilisateur>@<hostname>
Une boîte de dialogue apparaîtra et demandera le mot de passe.
Attention: Si vous ne mentionnez pas le nom d'utilisateur, c'est l'utilisateur courant sur la machine locale qui aura la main.
Le nouveau navigateur de KDE permet de faire ça très simplement.
Cliquez sur le raccourci Réseau
, puis Ajoutez un dossier réseau
. Remplissez ensuite les champs demandés. Pensez à mettre la racine (dossier /) comme dossier d'accès pour pouvoir rentrer sur l'intégralité de l'ordinateur distant.
Il est également possible de rentrer l'adresse et d'enregistrer le lien dans ses emplacements favoris :
sftp://nom_utilisateur@hostname:port
Parce qu'il est parfois nécessaire de faire un transfert de fichier à partir d'une machine sous MS Windows, il existe un logiciel libre nommé WinSCP
qui permet de faire du SFTP avec une interface semblable à celle des clients FTP.
Sans avoir à chercher trop loin, FileZilla, le client FTP compatible Linux, Windows et Mac OS X, permet aussi la connexion à un serveur SFTP (SSH File Transfer Protocol) depuis la version 3.
Dans la barre d'adresse de PCManFM, rentrez ceci :
sftp://nom_utilisateur_distant@IPduSERVEUR/dossier/que/je/veux
SSHFS est un outil permettant d'utiliser le protocole SSH comme un système de fichier et ainsi monter un répertoire distant à travers le protocole SSH pour y accéder comme n'importe quel répertoire local à la manière d'un partage NFS; mais sécurisé !
Voir la page SSH Filesystem.
Si vous ne pouvez vraiment pas faire autrement, utilisez des mots de passe longs et complexes ainsi qu'un système de protection tel que fail2ban qui permet de bannir des adresses IP au bout d'un certain nombre de tentatives erronées.
Voir aussi denyhosts notamment en cas de:
ssh_exchange_identification: read: Connection reset by peer
L'authentification par mot de passe (transmis chiffré) est le mode d'identification par défaut.
Autrefois tout le monde employait l'authentification typique par le principe identifiant - mot de passe. Cependant si quelqu'un connaît votre mot de passe ou le découvre au moyen d'une attaque la sécurité est compromise. De plus, utiliser un mot de passe différent pour chaque serveur et le saisir à chaque connexion peut s'avérer contraignant.
Pour se débarrasser des ces problèmes, SSH propose un système d'authentification par clé publique/privée au lieu des mots de passe « simples ».
Ceci peut permettre par exemple :
Ces clés restent des chaînes de caractères (en français courant : du texte), mais sont beaucoup plus longues et aléatoires que de simples mots de passe.
La clé privée est en principe unique : chaque utilisateur possède une clé privée qu'il peut copier sur les terminaux auxquels il accède physiquement et depuis lesquels il a besoin d'un accès SSH (via le client SSH). Cette clé se trouve généralement dans un fichier ~/.ssh/id_xxxx
. C'est un document sensible très personnel, il faut y appliquer des droits très restrictifs : r-x — —
(500) pour le répertoire .ssh et r– — —
(400) pour le fichier id_xxxx.
Pour un maximum de sécurité il est possible de protéger cette clé privée au moyen d'un mot de passe.
De son côté la clé publique est envoyée à tous les serveurs auxquels on veut accéder à distance afin qu'ils nous identifient avec certitude en vérifiant que le client possède bien la clé privée associée. Côté serveur cette clé publique sera stockée dans le fichier ~/.ssh/authorized_keys
, avec éventuellement des options et les clés publiques d'autres utilisateurs à raison d'une par ligne.
Localement on peut stocker une clé publique par ex. dans un fichier id_xxxx.pub
qui peut aussi se trouver dans le répertoire ~/.ssh
, ou ailleurs (ce n'est pas un document sensible).
On peut générer une nouvelle clé publique depuis une clé privée mais pas l'inverse.
À moins que vous n'ayez déjà un couple de clés, vous devez d'abord en créer.
Exemple pour une clé utilisant l'algorithme de chiffrement ED25519, vous saisirez dans le terminal du client :
ssh-keygen -t ed25519 -C "email@example.com"
On peut également utiliser l'algorithme plus ancien, moins sûr et générant des clés plus grosses RSA :
ssh-keygen -t rsa -b 4096 -C "email@example.com"
Il vous sera alors demandé où enregistrer la clé privée (acceptez juste l'endroit par défaut : ~/.ssh, et ne changez pas le nom du fichier généré) puis de choisir une passphrase (phrase de reconnaissance).
Votre clef publique a été créée avec la nouvelle clef privée. Elles sont habituellement localisées dans le dossier caché ~/.ssh:
~/.ssh/id_ed25519.pub pour la clé publique et ~/.ssh/id_ed25519 pour la clé privée ou ~/.ssh/id_ras.pub et ~/.ssh/id_rsa si vous avez utilisé l'algorithme RSA.
Pour que votre ssh-agent reconnaisse cette paire de clefs, il faut utiliser la commande ssh-add :
ssh-add #ou plus directement ssh-add /chemin-complet/vers-la-cle/nom-cle
Vous pouvez également vérifier la liste des paires de clefs existantes avec l'option -l (-list) :
ssh-add -l
The agent has no identities.
alors aucune clef n'est actuellement prise en compte. Il faut recommencer les étapes ci-dessus.
Si vous avez :
Could not open a connection to your authentication agent.
alors faire
eval "$(ssh-agent)"
puis de nouveau
ssh-add
ssh -o PubkeyAuthentication=yes -o PreferredAuthentications=publickey
Il faut maintenant envoyer au serveur votre clé publique pour qu'il puisse vous chiffrer des messages.
L'utilisateur distant doit avoir cette clé (c'est une ligne de caractères en code ASCII) dans son fichier de clés d'autorisation situé à ~/.ssh/authorized_keys sur le système distant. Employez la commande ssh-copy-id.
ssh-copy-id est un script qui utilise ssh pour se connecter à une machine à distance en utilisant le mot de passe de l'utilisateur. L'authentification par mot de passe doit donc être autorisée dans le fichier de configuration du serveur ssh (par défaut sur Ubuntu). Il change également les permissions des répertoires ~/.ssh et ~/.ssh/authorized_keys de l'hôte distant pour enlever l'accès en écriture du groupe (qui vous empêcherait de vous connecter si le serveur distant ssh a "StrictModes yes" dans son fichier de configuration, ce qui est le cas par défaut sur Ubuntu).
ssh-copy-id -i ~/.ssh/id_ed25519.pub <username>@<ipaddress>
ou si le port est différent du port standard 22 (notez les guillemets):
ssh-copy-id -i ~/.ssh/id_ed25519.pub -p <num_port> "<username>@<ipaddress>"
Vous devrez alors donner le mot de passe utilisateur de cet ordinateur. Après l'ajout votre clé publique, vous devenez un hôte de confiance.
Si l'authentification par mot de passe est désactivée1) , alors vous aurez besoin de copier-coller votre clé suivant un autre moyen.
Voici une ligne à copier pour ajouter sa clé publique sur le serveur distant :
ssh login@serveur "echo $(cat ~/.ssh/id_id_ed25519.pub) >> .ssh/authorized_keys"
Lancez :
ssh <username>@<ipaddress> -p <num_port>
Dorénavant n'utilisez plus votre mot de passe mais votre passphrase pour vous connecter. Celle-ci sert à déchiffrer votre clé privée de votre système local.
Si ça ne marche pas, c'est-à-dire que le mot de passe vous est quand même demandé, essayez sur votre serveur la commande :
tail -f /var/log/auth.log
tandis que vous essayez de vous connecter. Si on vous parle de "vulnkey", c'est que par malchance ssh-keygen
a généré une clé vulnérable. Recommencez alors la procédure depuis le début2)
Pour résumer, deux choses sont nécessaires pour obtenir un accès réellement sécurisant (et sécurisé ) par authentification à clé publique par rapport à l'authentification par mot de passe classique :
Si vous choisissez de ne pas avoir de mot de passe (ce qui est possible, voyez la prochaine section), vous aurez une sécurité moindre, ainsi que si vous utilisez une authentification uniquement par mot de passe, comparé à celle que vous pouvez avoir en combinant les deux.
Vous pouvez avoir avec SSH les deux modes d'authentifications actifs en même temps, par mot de passe et par clés.
Vous pouvez vouloir neutraliser l'authentification par mot de passe pour des raisons de sécurité, pour cela il faut modifier le fichier de configuration /etc/ssh/sshd_config de la manière suivante :
- A la ligne PasswordAuthentication
mettre no
Au mois de mai 2008 a été découvert une faiblesse dans la génération des clés par OpenSSL des packages Debian et dérivés tels qu'Ubuntu. Pour résumer, si vous avez généré vos clés entre 2006 et mai 2008, il faut en créer de nouvelles après avoir mis à jour le système. Pensez alors à bien rediffuser vos clés.
Si, après avoir suivi ce tutoriel, un mot de passe est toujours demandé, il se peut que ce soit dû à un problème de droits sur votre Dossier Personnel.
Sur la machine distante regardez le fichier /var/log/auth.log pour y trouver des indications et notamment si la ligne suivante apparaît :
Authentication refused: bad ownership or modes for directory /home/votre_login
Alors faites :
chmod 755 $HOME
Et tout devrait rentrer dans l'ordre.
Si ce n'est toujours pas le cas, c'est que le serveur doit être configuré en mode de sécurité strict (c'est le cas par défaut sur Ubuntu).
Effectuez les opérations suivantes :
Sur le serveur :
StrictModes yes
indique que le serveur va être très pointilleux sur les droits du compte sur lequel on se connecte en ssh.chmod go-w ~/ chmod 700 ~/.ssh chmod 600 ~/.ssh/authorized_keys
PreferredAuthentications publickey
.Parfois les clés de vos correspondants peuvent changer (réinstallation de machine par exemple), vous aurez alors droit à ce charmant message :
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY! Someone could be eavesdropping on you right now (man-in-the-middle attack)! It is also possible that the RSA host key has just been changed. The fingerprint for the RSA key sent by the remote host is xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx. Please contact your system administrator. Add correct host key in /home/<vous>/.ssh/known_hosts to get rid of this message. Offending key in /home/<vous>/.ssh/known_hosts:4 RSA host key for <ip> has changed and you have requested strict checking. Host key verification failed.
Soit l'information est exacte et une machine a été corrompue, ou bien il s'agit juste d'un changement de clé (réinstallation par exemple) et dans ce cas il faut effacer les entrées dans le fichier .ssh/known_hosts de votre compte.
Avant la chose était relativement simple, la clé était directement associée au nom ou à l'IP de la machine cible. Ce n'est plus le cas à présent où elle est associée par UUID rendant quasiment impossible l'identification visuelle de la ligne concernée. Mais ssh étant sympathique, il vous indique quelle est la ligne du fichier concernée.
Pour reprendre l'exemple précédent on peut lire la ligne Offending key in /home/<vous>/.ssh/known_hosts:4 → la clé en erreur est donc située ligne 4 du fichier .ssh/known_hosts
Il existe cependant une méthode plus subtile en employant la commande suivante :
ssh-keygen -R <ip>
Vous pourrez ainsi effacer seulement l'adresse IP concernée et relancer un ssh.
Si vous souhaitez vous connecter par SSH avec une clef publique sur un compte dont le home est chiffré, il est important de faire attention à ce que sur le serveur le fichier/dossier .ssh/authorized_keys soit à la fois dans le home chiffré et déchiffré. En effet si le fichier authorized_keys est dans le home sous forme chiffré (.private), open_ssh ne pourra pas lire la clef publique attendue. Il faut donc créer un dossier .ssh et y mettre le fichier authorized_keys quand le home est démonté donc chiffré. Cependant, si vous ne le laissez pas aussi dans le home déchiffré et donc monté, la connexion SSH se fera avec la clef publique mais le home ne sera pas déchiffré automatiquement.
La meilleure solution est de créer des liens virtuels vers un dossier qui n'est pas soumis au chiffrement/déchiffrement comme expliqué ici
En principe chaque utilisateur possède une clé privée unique qui lui est propre, et envoie sa clé publique à autant de serveurs qu'il le souhaite. Cependant il est techniquement faisable de posséder plusieurs clés privées (mais c'est moins pratique et ça n'est pas plus sécurisé).
Lorsqu'on se connecte à plusieurs serveurs avec des clés privées différentes, il faut pouvoir indiquer à SSH quelle clé on veut utiliser pour la connexion, sinon, on rencontre par exemple l'erreur:
git@gitlab.com: Permission denied (publickey).
Pour indiquer au client SSH la clé qu'il doit utiliser pour chacun des serveurs on peut créer un fichier ~/.ssh/config (ou /etc/ssh/ssh_config pour tous les utilisateurs de la machine) dans lequel il faut spécifier pour chacun des serveurs la clé qui doit être utilisée :
Host adresse-serveur-sans-passphrase.com User votreutilisateur IdentityFile ~/.ssh/key-sans-passphrase Host adresse-serveur-avec-passphrase.com User votreutilisateur IdentityFile ~/.ssh/key-avec-passphrase
Pour plus d'options, comme l'utilisateur ou le port à utiliser par défaut, voir le manuel de ssh_config, cf. aussi l'aide de gitlab (en)
Retrouver l'empreinte de notre clef SSH, pour la communiquer à une personne qui veut se connecter et va utiliser notre clef publique :
ssh-keygen -l
Ensuite la commande demande le fichier de la clef publique. Sur un serveur on spécifiera /etc/ssh/ssh_host_rsa_key.pub.
La configuration par défaut du serveur SSH sous Ubuntu est suffisante pour fonctionner correctement. Le fichier de configuration à éditer avec les droits d'administration est /etc/ssh/sshd_config.
Tableau des principales directives à modifier le cas échéant :
Directive du fichier | Valeur par défaut sous Ubuntu | Valeur possible | Effet de la valeur choisie |
---|---|---|---|
Port | 22 | Tous les ports qui ne sont pas utilisés par un autre service | Le changement du port par défaut , souvent conseillé, n'augmentera pas la sécurité. C'est même l'inverse si vous choisissez un port non privilégié, c'est à dire supérieur à 1024 |
PermitRootLogin | without-password / prohibit-password | yes no without-password forced-commands-only prohibit-password | cf le man |
PubkeyAuthentication | yes | no | Laisser yes si vous voulez établir l'authentification par clé comme expliqué plus haut |
PasswordAuthentication | yes | no | On peut parfaitement conserver l'authentification par clé pour certains utilisateurs avec celle par mot de passe pour d'autres utilisateurs. Conserver cette valeur à yes tant que l'authentification par clé n'est pas pleinement fonctionnelle, sinon vous perdrez toute connexion en SSH |
X11Forwarding | yes | no | Laisser yes pour faire de l'affichage graphique déporté |
#MaxStartups 10:30:60 | ligne commentée donc inactive | décommenter (enlever symbole #) | Le 10 représente le nombre de connexions acceptées sans qu'un utilisateur ait réussi à s'identifier, si cela passe au dessus de 10, il y a 30 % de probalités que les suivantes soient bloquées, et ce pourcentage augmente linéairement jusqu'à 100 % lorsque le full est atteint, à 60 connexions. Très utile pour éviter ce genre de désagrément. |
#Banner /etc/issue.net | Ligne commentée donc inactive | Décommenter | Lorsque vous essayez de vous connecter à votre serveur par SSH, le fichier /etc/issue.net est affiché (à vous de le personnaliser pour dire bonjour ou mettre un avertissement, un guide, etc.) |
UsePAM | yes | no | Attention, bien lire la page de man sshd_config, ce paramètre interagit avec ChallengeResponseAuthentication et PasswordAuthentication |
AllowUsers | Ligne absente (autorisé à tous) | ajouter la ligne avec valeur(s) : AllowUsers Alice Bob | Spécifie les logins des seuls utilisateurs autorisés à se connecter. Idéal pour ouvrir un compte FTP à un ami tout en restreignant l'accès au shell via SSH. |
DenyUsers | Ligne absente (interdit à personne) | Ajouter la ligne avec valeur(s) | Interdit l'accès à SSH aux utilisateurs listés |
AllowGroups | Ligne absente (autorisé à tous les groupes) | ajouter la ligne avec valeur(s) : AllowGroups groupname1 groupname2 | L'authentification via SSH ne sera possible que par des utilisateurs des groupes désigné par leur nom (pas par GID) |
DenyGroups | Ligne absente (interdit à aucun groupe) | Ajouter la ligne avec valeur(s) | Interdit l'accès à SSH aux utilisateurs des groupes listés |
ClientAliveInterval | Ligne absente | Ajouter la ligne avec valeur en secondes : ClientAliveInterval 300 | Permet dans certains cas de maintenir une connexion sans coupures |
Pour plus d'informations consultez man sshd_config
.
Le client peut aussi être configuré… via le fichier /etc/ssh/ssh_config Il est notamment intéressant d'ajouter
ServerAliveInterval 240
Pour que le client envoie des infos au server (ici toute les 4 minutes) et que ce dernier ne coupe pas la liaison, ce qui bloque (fige) le terminal. Pour voir les autres options: https://man.openbsd.org/ssh_config (en)
Il peut arriver que les ports des connexions entrantes sur un serveur SSH soient bloqués 3). Cependant, il est rare que les ports sortants soient fermés. Dans ce cas, il est possible de faire appel à du « Reverse-SSH » tel qu'expliqué dans cette page
Contributeurs: sx1, krodelabestiole, Zer00CooL, bruno