Hur man ställer in tvåfaktorsautentisering (2FA) för SSH på Debian 9 med Google Authenticator

Det finns flera sätt att logga in på en server över SSH. Metoder inkluderar lösenordsinloggning, nyckelbaserad inloggning och tvåfaktorsautentisering.

Tvåfaktorsautentisering är en mycket bättre typ av skydd. I händelse av att din dator äventyras, skulle angriparen fortfarande behöva en åtkomstkod för att logga in.

I den här handledningen kommer du att lära dig hur du ställer in tvåfaktorsautentisering på Debian 9 med Google Authenticator och SSH.

Förutsättningar

  • En Debian 9-server (eller nyare).
  • En icke-rootanvändare med sudo-åtkomst.
  • En smart telefon (Android eller iOS) med Google Authenticator-appen installerad. Du kan också använda Authy eller någon annan app som stöder tidsbaserade engångslösenord (TOTP) inloggningar.

Steg 1: Installera Google Authenticator Library

Vi måste installera modulen Google Authenticator Library som är tillgänglig för Debian, vilket gör att servern kan läsa och validera koder.

sudo apt update
sudo apt install libpam-google-authenticator -y

Steg 2: Konfigurera Google Authenticator för varje användare

Konfigurera modulen.

google-authenticator

När du kör kommandot kommer du att ställas vissa frågor. Den första frågan blirDo you want authentication tokens to be time-based (y/n)

Tryck på Yså får du en QR-kod, hemlig nyckel, verifieringskod och reservkoder för nödsituationer.

Ta fram telefonen och öppna Google Authenticator-appen. Du kan antingen skanna QR-koden eller lägga till den hemliga nyckeln för att lägga till en ny post. När du har gjort det, notera reservkoderna och förvara dem säkert någonstans. Om din telefon blir felplacerad eller skadad kan du använda dessa koder för att logga in.

För de återstående frågorna, tryck Ynär du ombeds att uppdatera .google_authenticatorfilen, Yför att inte tillåta flera användningar av samma token, Nför att öka tidsfönstret och för Yatt aktivera hastighetsbegränsning.

Du måste upprepa detta steg för alla användare på din maskin, annars kommer de inte att kunna logga in när du är klar med den här handledningen.

Steg 3: Konfigurera SSH för att använda Google Authenticator

Nu när alla användare på din maskin har konfigurerat sin Google-autentiseringsapp är det dags att konfigurera SSH för att använda denna autentiseringsmetod över den nuvarande.

Ange följande kommando för att redigera sshdfilen.

sudo nano /etc/pam.d/sshd

Hitta raden @include common-authoch kommentera den, som det som visas nedan.

# Standard Un*x authentication.
#@include common-auth

Lägg till följande rad längst ned i den här filen.

auth required pam_google_authenticator.so

Tryck på CTRL+ för Xatt spara och avsluta.

Ange sedan följande kommando för att redigera sshd_configfilen.

sudo nano /etc/ssh/sshd_config

Hitta termen ChallengeResponseAuthenticationoch ställ in dess värde till yes. PasswordAuthenticationHitta även termen , avkommentera den och ändra dess värde till no.

# Change to no to disable tunnelled clear text passwords
PasswordAuthentication no

Nästa steg är att lägga till följande rad längst ner i filen.

AuthenticationMethods publickey,keyboard-interactive

Spara och stäng filen genom att trycka på CTRL+ X. Nu när vi har konfigurerat SSH-servern för att använda Google Authenticator är det dags att starta om den.

sudo service ssh restart

Försök att logga in på servern igen. Den här gången kommer du att bli ombedd att ange din Authenticator-kod.

ssh user@serverip

Authenticated with partial success.
Verification code:

Ange koden som din app genererar så loggas du in.

Notera

Om du tappar bort din telefon, använd reservkoderna från steg 2. Om du tappade bort dina reservkoder kan du alltid hitta dem i .google_authenticatorfilen under användarens hemkatalog efter att du loggat in via Vultr-konsolen.

Slutsats

Att ha tvåfaktorsautentisering förbättrar avsevärt din servers säkerhet och låter dig hjälpa till att motverka vanliga brute force-attacker.


Installera Cacti på Debian Jessie

Installera Cacti på Debian Jessie

Introduktion Cacti är ett övervaknings- och grafverktyg med öppen källkod som är helt baserat på RRD-data. Genom Cacti kan du övervaka nästan vilken typ av enhet som helst

Konfigurera iRedMail på Debian Wheezy

Konfigurera iRedMail på Debian Wheezy

Använder du ett annat system? Den här handledningen visar dig hur du installerar groupware iRedMail på en ny installation av Debian Wheezy. Du bör använda en serve

How to Setup Unattended Upgrades on Debian 9 (Stretch)

How to Setup Unattended Upgrades on Debian 9 (Stretch)

Using a Different System? If you purchase a Debian server, then you should always have the latest security patches and updates, whether youre asleep or not

Konfigurera din egen DNS-server på Debian/Ubuntu

Konfigurera din egen DNS-server på Debian/Ubuntu

Denna handledning förklarar hur man ställer in en DNS-server med Bind9 på Debian eller Ubuntu. Genomgående i artikeln, byt ut ditt-domännamn.com i enlighet med detta. Vid th

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

I den här artikeln kommer vi att se hur man kompilerar och installerar Nginx mainline från de officiella källorna för Nginx med PageSpeed-modulen, som låter dig t

Hur man installerar Kanboard på Debian 9

Hur man installerar Kanboard på Debian 9

Använder du ett annat system? Introduktion Kanboard är ett gratis och öppen källkodsprogram för projektledningsprogram som är utformat för att underlätta och visualisera

Hur man installerar Gitea på Debian 9

Hur man installerar Gitea på Debian 9

Använder du ett annat system? Gitea är ett alternativt versionskontrollsystem med öppen källkod som drivs av Git. Gitea är skriven på Golang och är

Installera Lynis på Debian 8

Installera Lynis på Debian 8

Introduktion Lynis är ett gratis systemrevisionsverktyg med öppen källkod som används av många systemadministratörer för att verifiera integriteten och förstärka deras system. jag

Hur man installerar Thelia 2.3 på Debian 9

Hur man installerar Thelia 2.3 på Debian 9

Använder du ett annat system? Thelia är ett verktyg med öppen källkod för att skapa e-handelswebbplatser och hantera onlineinnehåll skrivet i PHP. Thelia källkod i

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Vad du behöver En Vultr VPS med minst 1 GB RAM. SSH-åtkomst (med root-/administrativa privilegier). Steg 1: Installera BungeeCord Först till kvarn

Hur man installerar Golang 1.8.3 på CentOS 7, Ubuntu 16.04 och Debian 9

Hur man installerar Golang 1.8.3 på CentOS 7, Ubuntu 16.04 och Debian 9

Golang är ett programmeringsspråk utvecklat av Google. Tack vare dess mångsidighet, enkelhet och tillförlitlighet har Golang blivit en av de mest populära

Återställ MySQL Root Password på Debian/Ubuntu

Återställ MySQL Root Password på Debian/Ubuntu

Om du har glömt ditt MySQL root-lösenord kan du återställa det genom att följa stegen i den här artikeln. Processen är ganska enkel och fungerar på dessa

Ställa in Counter Strike: Source på Debian

Ställa in Counter Strike: Source på Debian

I den här guiden kommer vi att sätta upp en Counter Strike: Source-spelserver på Debian 7. Dessa kommandon testades på Debian 7 men de borde också fungera o

Hur man installerar Unturned 2.2.5 på Debian 8

Hur man installerar Unturned 2.2.5 på Debian 8

I den här guiden kommer du att lära dig hur du ställer in en Unturned 2.2.5-server på en Vultr VPS som kör Debian 8. Obs: Detta är en redigerad version av Unturned som inte

Hur man installerar Cachet på Debian 8

Hur man installerar Cachet på Debian 8

I den här handledningen kommer du att lära dig hur du installerar Cachet på Debian 8. Cachet är ett kraftfullt statussidasystem med öppen källkod. Installation Den här handledningen pågår

Säkerhetskopiera flera MySQL- eller MariaDB-databaser automatiskt

Säkerhetskopiera flera MySQL- eller MariaDB-databaser automatiskt

Inledning I den här artikeln, gå igenom hur man säkerhetskopierar flera MySQL- eller MariaDB-databaser som sitter på samma maskin med hjälp av ett anpassat bash-skript

Konfigurera en Chroot på Debian

Konfigurera en Chroot på Debian

Den här artikeln kommer att lära dig hur du ställer in ett chroot-fängelse på Debian. Jag antar att du använder Debian 7.x. Om du kör Debian 6 eller 8 kan detta fungera, men

Hur man installerar Reader Self 3.5 RSS Reader på en Debian 9 LAMP VPS

Hur man installerar Reader Self 3.5 RSS Reader på en Debian 9 LAMP VPS

Använder du ett annat system? Reader Self 3.5 är ett enkelt och flexibelt, gratis och öppen källkod, RSS-läsare som är självvärd och Google Reader-alternativ. Läsare Sel

Hur man installerar Backdrop CMS 1.8.0 på en Debian 9 LAMP VPS

Hur man installerar Backdrop CMS 1.8.0 på en Debian 9 LAMP VPS

Använder du ett annat system? Backdrop CMS 1.8.0 är ett enkelt och flexibelt, mobilvänligt, gratis och open source Content Management System (CMS) som låter oss

Hur man installerar SteamCMD på din VPS

Hur man installerar SteamCMD på din VPS

I den här handledningen kommer vi att installera SteamCMD. SteamCMD kan användas för att ladda ner och installera många Steam-spelservrar, såsom Counter-Strike: Global Offensiv

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer