So richten Sie ein VPN mit OpenVPN auf Debian 9 Stretch Linux ein
- 2650
- 330
- Lana Saumweber
Verteilungen
Dieser Leitfaden wird für Debian 9 Stretch Linux getestet, kann jedoch mit anderen neueren Debian -Versionen funktionieren.
Anforderungen
- Diese Anleitung geht davon aus, dass Sie Debian auf einem VPS oder einem Remote -Server ausführen, da dies das wahrscheinlichste Szenario für ein VPN ist.
- Eine funktionierende Installation von Debian Stretch mit Root Access
Schwierigkeit
MITTEL
Konventionen
- # - erfordert, dass gegebene Linux -Befehle mit Root -Berechtigungen entweder direkt als Stammbenutzer oder mit Verwendung von ausgeführt werden können
sudo
Befehl - $ - Erfordert, dass die angegebenen Linux-Befehle als regelmäßiger nicht privilegierter Benutzer ausgeführt werden können
Iptables konfigurieren
Das Einrichten Ihres eigenen VPN ist keine kleine Aufgabe, aber es gibt viele Gründe, warum Sie dies tun möchten. Wenn Sie Ihr eigenes VPN ausführen, haben Sie die vollständige Kontrolle darüber und wissen genau, was es tut.
Sicherheit ist ein wichtiger Faktor für VPNs. Es ist möglich, in wenigen Minuten ein einfaches einzurichten, aber es wird überhaupt nicht sicher sein. Sie müssen die entsprechenden Schritte unternehmen, um sicherzustellen, dass sowohl der Server als auch Ihre Verbindungen privat und verschlüsselt bleiben.
Bevor Sie diese Straße abstellen, möchten Sie möglicherweise in Betracht ziehen, Ihre Festplatten zu verschlüsseln, die Kernelsicherheit mit Selinux oder Pax zu verbessern und sicherzustellen, dass alles andere gesperrt ist.
Iptables ist ein großer Teil der Serversicherheit. Sie benötigen Iptables, um sicherzustellen, dass diese Informationen nicht aus Ihrem VPN auslaufen. Iptables arbeitet auch daran, nicht autorisierte Verbindungen zu verhindern. Der erste Schritt bei der Einrichtung eines VPN auf Debian besteht darin, Iptables einzurichten.
Finden Sie Ihre WAN -Schnittstelle
Bevor Sie mit dem Schreiben Ihrer Iptables -Regeln beginnen können, müssen Sie wissen, für welche Schnittstelle Sie sie schreiben.
Verwenden Ifconfig
oder ip a
So suchen Sie nach der Schnittstelle, mit der Ihr Server mit dem Internet verbunden ist.
Der Rest dieser Anleitung bezieht sich auf diese Schnittstelle als Eth0
, Aber das wird wahrscheinlich nicht dein sein. Stellen Sie stattdessen sicher, dass Sie den Namen der Netzwerkschnittstelle Ihres Servers auszeigen.
Erstellen der Iptables -Regeln
Jeder Linux -Benutzer und jeder Administrator liebt es, iptables Regeln zu schreiben, richtig? Es wird nicht so schlimm sein. Sie komponieren eine Datei mit allen Befehlen und stellen sie einfach in Iptables wieder her.
Erstellen Sie Ihre Datei. Sie können es an einen Ort schaffen, an dem Sie es speichern oder einfach hineinwerfen möchten /tmp
. Iptables speichert Ihre Regeln sowieso, also /tmp
ist gut.
$ VIM /TMP /V4RULES
Starten Sie die Datei durch Hinzufügen aus *Filter
Iptables wissen zu lassen, dass dies Filterregeln sind.
Ja, es wird auch einen IPv6 geben, aber es wird viel kürzer sein.
Loopback -Regeln
Beginnen Sie mit dem einfachsten Satz von Regeln, den Loopback -Schnittstellen, die. Diese sagen nur Iptables, sie sollen nur Looback -Verkehr von Localhost akzeptieren.
-Ein Eingang -i lo -j Akzeptieren Sie -a Eingabe ! -I lo -s 127.0.0.0/8 -j ablehnen -a output -o lo -j Akzeptieren
Ping zulassen
Als nächstes möchten Sie wahrscheinlich in der Lage sein, Ihren Server zu pingen. Diese Gruppe von Regeln erlaubt Ping durch.
-Ein Eingabe -p -ICMP -M -Zustand -State New -ICMP -Typ 8 -j Accept -a Eingabe -p ICMP -M -Zustand -State etabliert, verwandte -j Accept -a -Ausgabe -p ICMP -J Akzeptieren
SSH -Setup
Sie sollten wahrscheinlich SSH in Port 22 ändern. Lassen Sie Ihre Regeln also widerspiegeln.
-Ein Eingang -i Eth0 -p tcp -m -Zustand -State Neu, etabliert -dort 22 -j Akzeptieren -Ein Ausgang -o ETH0 -P TCP -M -Staat -State etabliert --sport 22 -j Akzeptieren
OpenVPN durch
Offensichtlich möchten Sie den OpenVPN -Verkehr durch. Diese Anleitung wird UDP für OpenVPN verwenden. Wenn Sie sich für TCP entscheiden, lassen Sie die Regeln dies widerspiegeln.
-Ein Eingabe -i Eth0 -p udp -m Staat -State Neu, etabliert -dort 1194 -j ACKETPEN -A OUTTION -O ETH0 -P UDP -M -Staat -State etabliert -Ssport 1194 -J Akzeptieren
DNS
Sie möchten auch DNS -Verkehr über Ihren VPN -Server zulassen. Dies wird sowohl über UDP als auch über TCP geschehen.
-Ein Eingang -i Eth0 -p UDP -M -Staat -State festgelegt - -ssport 53 -j Accept -a Output -o Eth0 -p UDP -M -Zustand -State Neu, etabliert -dort 53 -j Accept -a Input -i eth0 -p tcp -m staat
HTTP/s für Updates
Es mag seltsam erscheinen, HTTP/s -Verkehr zuzulassen, aber Sie Tun Ich möchte, dass Debian sich selbst aktualisieren kann, richtig? Diese Regeln ermöglichen es Debian, HTTP -Anfragen zu initiieren, sie jedoch nicht von außen zu erhalten.
-Ein Eingang -i Eth0 -p TCP -M -Zustand -State festgelegt - -ssport 80 -j Accept -a Input -i eth0 -p tcp -m Status -State festgelegt -Ssport 443 -j Accept -a Output -o ETH0 -P TCP -M -Staat -State neu, etabliert -dort 80 -j Akzeptieren -a output -o eth0 -p tcp -m Staat -State neu, etabliert -dort 443 -J Akzeptieren
NTP, um Ihre Uhr zu synchronisieren
Angenommen, Sie werden Ihre Serveruhr und die Clientuhren nicht manuell synchronisieren, benötigen Sie NTP. Erlaube es auch.
-Ein Eingang -i Eth0 -p UDP -M -Staat -State festgelegt - -ssport 123 -j Akzeptieren
Tun zum Tunnel durch das VPN
In dieser Anleitung wird Tun zum Tunnel durch das VPN verwendet. Wenn Sie TAP verwenden, passen Sie entsprechend an.
-Ein Eingang -i Tun0 -J Akzeptieren Sie -a Forward -i Tun0 -j Akzeptieren Sie -a output -o tun0 -j Akzeptieren
Damit das VPN Ihren Datenverkehr an das Internet weiterleitet.
-Ein vorwärts -i Tun0 -o eth0 -s 10.8.0.0/24 -J Akzeptieren Sie -a Forward -m State -State etabliert, verwandte -j akzeptieren
Protokoll blockierte Verkehr
Sie sollten wahrscheinlich Iptables den Datenverkehr protokollieren, den es blockiert. Auf diese Weise sind Sie sich jeder potenziellen Bedrohungen bewusst.
-Ein Eingabe -M -Grenzwert -limit 3/min -j log -log -prefix "iptables_input_denied:" -Log -Level 4 -a Forward -m -Limit - -limit 3/min -j log -log -prefix " Iptables_forward_Denied: " -Log -Level 4 -a Ausgabe -m -Grenze - -limit 3/min -j log - -log -prefix" iptables_output_Denied: " -Log -Level 4
Alle anderen Verkehrsdaten ablehnen
Jetzt, da Sie alles protokollieren, was nicht in die vorhandenen Regeln passt, lehnen Sie es ab.
-Ein Eingang -j Ablehnung -a vorwärts -j ablehnen -a output -j ablehnen
Vergessen Sie nicht, Ihre Datei mit zu schließen BEGEHEN
.
Nat
Dieser nächste Teil erfordert eine andere Tabelle. Sie können es nicht derselben Datei hinzufügen, sodass Sie den Befehl einfach manuell ausführen müssen.
Machen Sie den Datenverkehr von der VPN -Maskerade als Datenverkehr von der physischen Netzwerkschnittstelle.
# iptables -t nat -a poTrouting -s 10.8.0.0/24 -O ETH0 -J Maskerade
Blockieren Sie den gesamten IPv6 -Verkehr
Der Datenverkehr kann über IPv6 austreten, und es ist wirklich keine Notwendigkeit, IPv6 zu verwenden. Am einfachsten ist es, es ganz zu schließen.
Erstellen Sie eine andere Datei und werfen Sie die Regeln ein, um den gesamten IPv6 -Datenverkehr abzulehnen.
$ VIM /TMP /V6RULES
*filter -a Eingabe -j ablehnen -a vorwärts -j reject -a output -j reject Commit
Alles begehen
Beginnen Sie damit, alle vorhandenen Iptables -Regeln auszuspülen.
# iptables -f && iptables -x
Importieren Sie jede der von Ihnen erstellten Regelndateien.
# iptables-restore < /tmp/v4rules # ip6tables-restore < /tmp/v6rules
Es kleben lassen
Debian verfügt über ein Paket, das automatisch Ihre iptierbaren Regeln lädt, sodass Sie keinen Cron -Job oder ähnliches erstellen müssen.
# APT ITTABLES-PERSISTENT INSTALLIEN
Im Installationsprozess werden Sie gefragt, ob Sie Ihre Konfigurationen speichern möchten. Antwort: "Ja."
In Zukunft können Sie Ihre Regeln aktualisieren, indem Sie den folgenden Linux -Befehl ausführen.
# Service Netfilter-Persistent Save
Zusätzliche Konfiguration
Es gibt noch ein paar weitere Dinge, die Sie tun müssen, um alle Ihre Netzwerkschnittstellen bei Bedarf zu bearbeiten.
Erstens öffnen Sie /etc/hosts
und kommentieren Sie alle IPv6 -Zeilen.
Als nächstes offen /etc/sysctl.D/99-SYSCTL.Conf
. Die folgende Zeile finden und überzeugen.
Netz.IPv4.ip_forward = 1
Fügen Sie diese nächsten Zeilen hinzu, um IPv6 vollständig zu deaktivieren.
Netz.IPv6.Conf.alle.disable_ipv6 = 1 net.IPv6.Conf.Standard.disable_ipv6 = 1 net.IPv6.Conf.LO.disable_ipv6 = 1 net.IPv6.Conf.Eth0.disable_ipv6 = 1
Schließlich wenden Sie Ihre Änderungen an.
# sysctl -p
Was kommt als nächstes
Das ist der erste Teil down. Die Firewall Ihres Servers ist jetzt bereit, OpenVPN auszuführen, und Ihr Netzwerk ist auch richtig ausgerichtet.
Der nächste Schritt besteht darin, eine Zertifikatberechtigung zu erstellen, um alle Ihre Verschlüsselungsschlüssel zu verarbeiten. Es ist kein langwieriger Prozess wie dies, aber es ist genauso wichtig.
Zertifizierungsstelle
Verwenden.
Dies ist der zweite Teil bei der Konfiguration eines OpenVPN -Servers auf Debian Stretch.
VPNs verlassen sich auf Verschlüsselung. Es ist absolut wichtig, dass sie ihre Verbindungen zu Kunden sowie den Verbindungsprozess selbst verschlüsseln.
Um die für verschlüsselten Kommunikation erforderlichen Schlüssel zu generieren, müssen Sie eine Zertifikatbehörde festlegen. Es ist wirklich nicht so schwierig und es gibt Tools, die den Prozess weiter vereinfachen.
Installation der Pakete
Installieren Sie vor dem Start OpenVPN und Easy-RSA.
# APT INSTALLEN SIE OpenVPN Easy-RSA
Richten Sie das Verzeichnis ein
Das OpenVPN -Paket hat ein Verzeichnis für sich selbst erstellt /etc/openVPN
. Hier können Sie die Zertifikatautorität einrichten.
Easy-RSA enthält ein Skript, das automatisch ein Verzeichnis mit allem erstellt, was Sie benötigen. Verwenden Sie es, um Ihr Verzeichnis für die Zertifikatberechnung zu erstellen.
# Make-Cadir/etc/openVPN/certs
Geben Sie dieses Verzeichnis ein und erstellen Sie einen Soft Link zwischen der neuesten OpenSSL -Konfiguration mit OpenSSL.CNF
.
# ln -S OpenSSL -1.0.0.CNF OpenSSL.CNF
Stellen Sie die Variablen ein
Im Ordner befindet sich eine Datei mit dem Namen, vars
. Diese Datei enthält die Variablen, mit denen Easy-RSA Ihre Schlüssel generiert. Öffne es. Es gibt einige Werte, die Sie ändern müssen.
Beginnen Sie mit der Suche die Key_size
variabel und verändern den Wert zu Wert zu 4096
.
exportieren key_size = 4096
Suchen Sie als Nächst.
export key_country = "us" export key_province = "ca" export key_city = "sanfrancisco" Export key_org = "Fort-Funston" Export key_email = "[email protected] "export key_ou =" myorganizationalUnit "
Ändern Sie die Werte, die Ihnen entsprechen,.
Die letzte Variable, die Sie finden müssen, ist die KEY_NAME
export key_name = "vpnserver"
Nennen Sie es etwas identifizierbares.
Erstellen Sie die Autoritätstasten
Easy-RSA enthält Skripte, um die Zertifikatautorität zu generieren.
Laden Sie zuerst die Variablen.
# Quelle ./vars
Eine Warnmeldung wird im Terminal angezeigt, das Ihnen das sagt alles putzen
wird Ihre Schlüssel löschen. Du hast noch keine, also ist es in Ordnung.
# ./alles putzen
Sie können jetzt das Skript ausführen, um Ihre Zertifikatautorität tatsächlich zu generieren. Das Skript stellt Ihnen Fragen zu den Tasten, die Sie generieren. Die Standardantworten sind die Variablen, die Sie bereits eingegeben haben. Sie können sicher zerschlagen "eintreten."Denken Sie daran, ein Passwort einzugeben, wenn Sie möchten, und beantworten Sie" Ja "zu den letzten beiden Fragen.
# ./bau-ca
Erstellen Sie einen Serverschlüssel
Diese Schlüssel, die Sie gemacht haben, waren für die Zertifikatbehörde selbst. Sie benötigen auch einen Schlüssel für den Server. Noch einmal gibt es ein Skript dafür.
# ./build-key-server-Server
Erzeugen Sie einen Diffie-Hellman-Pem
Sie müssen einen Diffie-Hellman-PEM erstellen, mit dem OpenVPN sichere Client-Sitzungen erstellen wird. Easy-RSA bietet auch ein Skript dafür, aber es ist einfach einfacher, Plain OpenSSL zu verwenden.
Da das Ziel hier Sicherheit ist, ist es am besten, einen 4096 -Bit -Schlüssel zu generieren. Die Erzeugung wird einige Zeit dauern, und es kann den Verbindungsprozess ein wenig verlangsamen, aber die Verschlüsselung wird einigermaßen stark sein.
# OpenSSL DHPARAM 4096>/etc/openvpn/dh4096.Pem
Generieren Sie einen HMAC -Schlüssel
Ja, Sie brauchen einen weiteren Verschlüsselungsschlüssel. OpenVPN verwendet HMAC -Tasten, um die Pakete zu signieren, die sie im TLS -Authentifizierungsprozess verwendet. Durch die Unterzeichnung dieser Pakete kann OpenVPN garantieren, dass nur Pakete, die von einer Maschine mit dem Schlüssel stammen, akzeptiert werden. Es fügt nur eine weitere Sicherheitsebene hinzu.
Das Dienstprogramm zur Generierung Ihres HMAC -Schlüssels ist tatsächlich in OpenVPN selbst integriert. Starte es.
# OpenVPN --Genkey -Sekret/etc/openVPN/certs/keys/ta.Taste
Was kommt als nächstes
Das Erstellen einer starken Verschlüsselung ist einfach einer der wichtigsten Aspekte bei der Einrichtung eines OpenVPN -Servers. Ohne gute Verschlüsselung ist der gesamte Prozess im Grunde genommen bedeutungslos.
Zu diesem Zeitpunkt sind Sie endlich bereit, den Server selbst zu konfigurieren. Die Serverkonfiguration ist tatsächlich weniger kompliziert als bisher, also herzlichen Glückwunsch.
OpenVPN Sever
Konfigurieren Sie den OpenVPN -Server mit den Verschlüsselungsschlüssel, die Sie im vorherigen Abschnitt des Handbuchs generiert haben.
Dies ist der dritte Teil bei der Konfiguration eines OpenVPN -Servers auf Debian Stretch.
Jetzt sind Sie beim Hauptereignis angekommen. Dies ist die tatsächliche OpenVPN -Serverkonfiguration. Alles, was Sie bisher getan haben, war absolut notwendig, aber nichts davon hat OpenVPN selbst berührt, bis jetzt.
Dieser Abschnitt befasst sich völlig mit der Konfiguration und Ausführung des OpenVPN -Servers und ist tatsächlich weniger kompliziert als Sie wahrscheinlich denken.
Holen Sie sich die Basiskonfiguration
OpenVPN hat diesen Prozess gemacht sehr einfach. Das von Ihnen installierte Paket wurde mit Beispielkonfigurationsdateien für sowohl Clients als auch für den Server ausgestattet. Sie müssen nur den Server in Sie entpacken /etc/openVPN
Verzeichnis.
# Gunzip -c/usr/share/doc/openVPN/Beispiele/Beispiel-Config-Files/Server.Conf.GZ>/etc/openVPN/Server.Conf
Öffnen Sie es in Ihrem bevorzugten Texteditor und machen Sie sich bereit, die Dinge zu ändern.
Verwenden Sie Ihre Schlüssel
Sobald Sie sich in der Datei befinden, werden Sie feststellen, dass alles mit angemessenen Standardeinstellungen ausgefüllt ist, und es gibt viele Kommentare, die eine hervorragende Dokumentation dessen liefern, was alles tut.
Das erste, was Sie finden müssen. Die Variablen sind ca
, Zertifikat
, Und Taste
. Stellen Sie sie gleich dem vollständigen Pfad jeder dieser Dateien ein. Es sollte wie das Beispiel unten aussehen.
ca/etc/openVPN/certs/keys/ca.CRT Cert/etc/openVPN/certs/Schlüssel/Server.CRT -Schlüssel/etc/openVPN/certs/Schlüssel/Server.Schlüssel # Diese Datei sollte geheim gehalten werden
Der nächste Teil, den Sie finden müssen, ist der Diffie-Hellman .Pem
Wenn Sie fertig sind, sollte es so aussehen:
DH DH4096.Pem
Schließlich finden Sie tls-auth
Für Ihren HMAC -Schlüssel.
tls-auth/etc/openvpn/certs/keys/ta.Schlüssel 0 # Diese Datei ist geheim
Ja, lass das 0
dort.
Sicherheit verstärken
Die Verschlüsselungseinstellungen in der Konfigurationsdatei sind in Ordnung, aber sie könnten es sein viel besser. Es ist Zeit, bessere Verschlüsselungseinstellungen zu ermöglichen.
Finden Sie den Abschnitt, der mit beginnt mit, # Wählen Sie eine kryptografische Chiffre.
Hier müssen Sie die folgende Zeile unten hinzufügen, die er vorhanden ist.
CIPHER AES-256-CBC
Es ist nicht eine der aufgelisteten Optionen dort, aber es wird von OpenVPN unterstützt. Diese 256 -Bit -AES -Verschlüsselung ist wahrscheinlich die beste, die von OpenVPN angeboten wird.
Scrollen Sie bis zum Ende der Datei. Die nächsten beiden Optionen sind nicht bereits in der Konfiguration, daher müssen Sie sie hinzufügen.
Zuerst müssen Sie eine starke Authentifizierungsdigest angeben. Dies ist die Verschlüsselung, die OpenVPN für die Benutzerauthentifizierung verwendet. Wählen Sie SHA512.
# Auth Digest Auth SHA512
Beschränken Sie als nächstes die Chiffren, die OpenVPN verwenden, um stärker zu werden. Es ist am besten, es so weit wie möglich zu beschränken.
# Begrenzung Chiffren Tls-Cipher TLS-DHE-RSA-WITH-AES-256-GCM-SHA384: TLS-DHE-RSA-WITH-AES-128-GCM-SHA256: TLS-DHE-RSA-WITH-AES-256- CBC-Sha: TLS-DHE-RSA-WITH-Camellia-256-CBC-Sha: TLS-DHE-RSA-WITH-AES-128-CBC-SHA: TLS-DHE-RSA-WITH-Camellia-128-CBC- Sha
Direkten Verkehr
Das gesamte Verschlüsselungsmaterial ist aus dem Weg. Es ist Zeit, Routing zu machen. Sie müssen OpenVPN sagen, um den Umleitungsverkehr und DNS zu verarbeiten.
Beginnen Sie mit dem Umleiten des Verkehrs. Finden Sie die Linie unten und kontrollieren Sie sie.
Drücken Sie "Redirect-Gateway Def1 Bypass-DHCP"
Um DNS über OpenVPN zu leiten, müssen Sie ihm DNS -Optionen geben. Diese Zeilen sind bereits da und kommentiert auch. Sie überzeugen. Wenn Sie einen anderen DNS -Server verwenden möchten, können Sie die IP auch in diesen DNS ändern.
Drücken Sie "DHCP-Option DNS 208".67.222.222 "Push" DHCP-Option DNS 208.67.220.220 "
Richten Sie einen OpenVPN -Benutzer ein
OpenVPN wird standardmäßig als Root ausgeführt. Das ist eine ziemlich schreckliche Idee. Wenn OpenVPN kompromittiert ist, verschraubt das gesamte System des gesamten Systems. Es gibt ein paar kommentierte Zeilen, die OpenVPN als "niemand" ausführen, aber "Niemand" führt normalerweise auch andere Dienste aus. Wenn Sie nicht möchten, dass OpenVPN Zugriff auf etwas anderes als openVPN hat, müssen Sie es als seinen eigenen nicht privilegierten Benutzer ausführen.
Erstellen Sie einen Systembenutzer, damit OpenVPN ausgeführt werden kann.
# adduser--System-Shell/usr/sbin/nologin-no-create-home openvpn
Anschließend können Sie die Konfigurationsdatei bearbeiten, indem Sie die Zeilen, in denen OpenVPN als "niemand" ausgeführt wird.
Benutzer OpenVPN -Gruppe NOGROUP
Senden Sie Protokolle an NULL
Es gibt zwei Optionen, wenn es um Protokolle geht, und beide haben ihre Verdienste. Sie können alles als normal protokollieren und die Protokolle zu einem späteren Zeitpunkt wieder einschalten lassen, oder Sie können paranoid und log /dev/null
.
Durch Anmelden an /dev/null
, Sie löschen jede Aufzeichnung der Kunden, die sich mit dem VPN verbinden und wohin sie gehen. Obwohl Sie Ihr VPN kontrollieren, möchten Sie diesen Weg möglicherweise gehen, wenn Sie versuchen, mehr Privatsphäre zu sein.
Wenn Sie Ihre Protokolle zerstören möchten, finden Sie die Status
, Protokoll
, Und Protokollanordnung
Variablen und richten Sie sie alle auf /dev/null
. Es sollte dem Beispiel unten ähnlich aussehen.
Status /dev /null… log /dev /null log-append /dev /null
Das ist der letzte Teil der Konfiguration. Speichern Sie es und machen Sie sich bereit, Ihren Server auszuführen.
Führen Sie Ihren Server aus
Es gibt tatsächlich zwei Dienste, die Sie benötigen, um OpenVPN auf Debian Stretch zu verbessern. Starten Sie beide mit Systemd.
# SystemCTL Start OpenVPN # systemctl starten openvpn@server
Stellen Sie sicher, dass sie ordnungsgemäß laufen.
# Systemctl Status OpenVPN*.Service
Ermöglichen es ihnen, beide beim Start zu laufen.
# systemCTL aktivieren openVPN # systemCTL OpenVPN@Server aktivieren
Sie haben jetzt einen laufenden VPN -Server auf Debian Stretch!
Was kommt als nächstes
Du bist hier. Du hast es geschafft! Debian führt jetzt OpenVPN hinter einer sicheren Firewall durch und es ist bereit, dass Kunden eine Verbindung herstellen.
Im nächsten Abschnitt richten Sie Ihren ersten Client ein und verbinden ihn an Ihren Server.
OpenVPN -Client
Konfigurieren und OpenVPN -Client, um eine Verbindung zum neu konfigurierten OpenVPN -Server herzustellen.
Dies ist der vierte und letzte Teil bei der Konfiguration eines OpenVPN -Servers auf Debian Stretch.
Nachdem Ihr Server ausgeführt wird, können Sie einen Client einrichten, um eine Verbindung dazu herzustellen. Dieser Client kann jedes Gerät sein, das OpenVPN unterstützt, was fast alles ist.
Es gibt etwas, das Sie auf dem Server zuerst an den Client geben müssen, aber danach geht es darum, diese Verbindung aufzubauen.
Clientschlüssel erstellen
Beginnen Sie mit einer Reihe von Clientschlüssel. Der Prozess ist fast identisch mit dem, den Sie verwendet haben, um die Serverschlüssel zu erstellen.
CD
Stellen Sie die Quelle in das Verzeichnis der Zertifikatbehörde aus der Variablen -Datei ein und erstellen Sie die Schlüssel.
# CD/etc/openvpn/certs # Quelle ./vars # ./Build-Key FirstClient
Sie können den Client -Schlüssel nennen, was auch immer Sie wählen,. Das Skript wird Ihnen erneut eine Reihe von Fragen stellen. Die Standardeinstellungen sollten für alles gut sein.
Client -Konfigurationsdatei
OpenVPN bietet Beispielclient -Konfigurationen zusätzlich zu den Server. KREATE ein neues Verzeichnis für Ihre Client -Konfiguration und kopieren Sie das Beispiel in.
# Mkdir/etc/openVPN/Clients # CP/usr/share/doc/openVPN/Beispiele/Beispiel-Config-Files/Client/Client.conf/etc/openvpn/client/client.ovpn
Öffnen Sie die Datei in Ihrem Texteditor Ihrer Wahl.
Remote-Host
Finden Sie die Linie mit der Fernbedienung
Variable. Stellen Sie es gleich der IP Ihres Servers ein.
Fernbedienung 192.168.1.5 1194
Werden niemand
Es gibt kein Training mit den gesichtslosen Männern, die erforderlich sind. Finden Sie einfach eine Überzeugung, die Linien unten.
Benutzer Niemand Gruppennogroup
Richten Sie Ihre Schlüssel ein
Sie müssen der Client -Konfiguration mitteilen, wo die Schlüssel zu finden ist, die sie auch benötigt. Suchen Sie die folgenden Zeilen und bearbeiten Sie sie so, dass Sie das übereinstimmen, was Sie eingerichtet haben.
ca ca.CRT Cert FirstClient.CRT Key FirstClient.Taste
Stellen Sie sicher. Der Weg ist in Ordnung. Sie werden alles in das gleiche Verzeichnis setzen.
Finden und überzeugen Sie die Linie für HMAC.
tls-auth ta.Schlüssel 1
Verschlüsselung angeben
Der Client muss wissen, welche Verschlüsselung der Server verwendet. Genau wie der Server müssen einige dieser Zeilen hinzugefügt werden.
Finde die Chiffre
Variable. Es wird kommentiert. Überzeugen Sie es und fügen Sie die Chiffre hinzu, die Sie auf dem Server verwendet haben.
CIPHER AES-256-CBC
Fügen Sie die Authentifizierungsdigest und die Cipher -Beschränkungen am Ende der Clientkonfiguration hinzu.
# Authentifizierung Digest Auth SHA512 # CIPHER-Beschränkungen tls-cipher tls-dhe-rsa-with-aes-256-gcm-sha384: tls-dhe-RSA -Aes-256-CBC-Sha: TLS-DHE-RSA-WITH-Camellia-256-CBC-Sha: TLS-DHE-RSA-WITH-128-CBC-SHA: TLS-DHE-RSA-WITH-Camellia -128-CBC-Sha
Speichern Sie Ihre Konfiguration und beenden Sie.
Senden Sie dem Kunden einen Tarball
Sie müssen Ihre Client -Konfiguration und -tasten in einem Tarball packen und an den Client senden. Laden Sie alles in einen Tarball, um die Dinge am Kundenende zu vereinfachen.
# TAR CJF/ETC/OpenVPN/Clients/FirstClient.Teer.xz -c/etc/openvpn/certs/keys ca.CRT FirstClient.CRT FirstClient.Key Ta.Key -c/etc/openvpn/client/client.ovpn
Jetzt können Sie diesen Tarball an Ihren Kunden übertragen, wie Sie es wählen,.
Verbinden
Unter der Annahme, dass Ihr Kunde eine Debianverteilung ist, ist der Verbindungsprozess sehr einfach. Installieren Sie OpenVPN, wie Sie es auf dem Server getan haben.
# APT OpenVPN installieren
Extrahieren Sie Ihren Tarball in die /etc/openVPN
Verzeichnis, das die Installation erstellt hat.
# CD/etc/openvpn # tar xjf/path/to/firstClient.Teer.xz
Möglicherweise müssen Sie umbenennen Klient.ovpn
Zu OpenVPN.Conf
. Wenn Sie dies tun.
Starten und aktivieren OpenVPN mit Systemd.
# Systemctl starten openVPN # systemctl aktivieren openVPN
Abschluss
Sie haben einen funktionierenden VPN -Server und einen angeschlossenen Client! Sie können dieselbe Prozedur befolgen, die in diesem Leitfaden auch für Ihre anderen Kunden ausführlich beschrieben ist. Stellen Sie sicher, dass Sie für jeden separaten Schlüssel erstellen. Sie können jedoch dieselbe Konfigurationsdatei verwenden.
Vielleicht möchten Sie auch sicherstellen, dass alles richtig funktioniert. Gehen Sie zum DNS -Lecketest, um sicherzustellen.
Verwandte Linux -Tutorials:
- Basic Ubuntu 22.04 OpenVPN -Client/Server -Verbindungsanschluss -Setup
- So richten Sie einen OpenVPN -Server auf Ubuntu 20 ein.04
- Dinge zu installieren auf Ubuntu 20.04
- Dinge zu tun nach der Installation Ubuntu 20.04 fokale Fossa Linux
- Linux -Download
- Installieren Sie Arch Linux in VMware Workstation
- Beste Linux -Distribution für Entwickler
- Linux -Befehle: Top 20 wichtigste Befehle, die Sie benötigen, um…
- So erstellen Sie ein VPN auf Ubuntu 20.04 Verwenden von Drahtguard
- Eine Einführung in Linux -Automatisierung, Tools und Techniken
- « VNC Server/Client -Setup auf Debian 9 Stretch Linux
- So installieren Sie MySQL Community Server auf Debian 9 Stretch Linux »