Ansluta flera Vultr-zoner med N2N

N2N är en öppen källkod lager 2/3 VPN-applikation. Till skillnad från många andra VPN-program kan N2N ansluta datorer som är placerade bakom en NAT-router. Detta ger en stor fördel att ansluta till en molnmiljö utan att behöva förlita sig på speciella protokoll som ESP-protokollet (används av ipsec). För att uppnå denna anslutning använder N2N en supernod som kan dirigera informationen mellan NAT-styrda noder. Denna VPN-anslutning kan användas för att koppla ihop flera Vultr-instanser över regioner.

Förutsättningar

I det här exemplet kommer vi att använda tre noder i flera zoner:

  • Paris
  • Miami
  • Sydney

Installation av programvaran

Följande kommandon kommer att köras på varje instans.

Börja med att installera build-essentialfrån repo och även libssl-dev, eftersom vi kommer att bygga från den senaste källkoden.

apt-get install -y build-essential libssl-dev

Ladda sedan ner källkoden från github.

cd /tmp
git clone https://github.com/ntop/n2n.git

Kompilera alla binärer.

cd n2n 
make
make install

Det make installkommando kommer att ha skapat supernodeoch edgebinär i /usr/sbinkatalogen. Avsluta med att rensa upp filerna.

rm -rf /tmp/n2n

Installation - Node Paris

Den första noden kommer att vara vår så kallade supernod. Denna supernod kommer att starta supernodtjänsten som lyssnar på UDP-porten 1200. Som standard skapar N2N-applikationen inte en servicefil. Så vi kommer att behöva tillhandahålla vår egen.

Skapa tjänsten 'n2n_supernode':

nano /etc/systemd/system/n2n_supernode.service

Lägg till följande innehåll:

[Unit]
Description=n2n supernode
Wants=network-online.target
After=network-online.target

[Service]
ExecStart=/usr/sbin/supernode -l 1200

[Install]
WantedBy=multi-user.target

Direktivet '-l' definierar UDP-porten 1200. Detta är porten som supernoden kommer att lyssna på. För att säkerställa att allt fungerar, starta supernodtjänsten:

systemctl start n2n_supernode

Kontrollera supernodens status.

systemctl status n2n_supernode

Detta kommer att visa en status som liknar följande.

● n2n_supernode.service - n2n supernode
   Loaded: loaded (/etc/systemd/system/n2n_supernode.service; disabled; vendor prese
   Active: active (running) since Wed 2018-08-15 17:07:46 UTC; 5s ago
 Main PID: 4711 (supernode)
    Tasks: 1
   Memory: 80.0K
      CPU: 1ms
   CGroup: /system.slice/n2n_supernode.service
           └─4711 /usr/sbin/supernode -l 1200

Därefter kommer vi att skapa edge-tjänsten. Denna edge-tjänst kommer att göra anspråk på en privat IP för kommunikation mellan de andra kanterna i andra Vultr-zoner.

Precis som med supernodtjänsten kommer denna också att behöva en egen tjänstfil.

nano /etc/systemd/system/n2n_edge.service

Lägg till följande innehåll:

[Unit]
Description=n2n edge
Wants=network-online.target
After=network-online.target n2n_supernode.service

[Service]
ExecStart=/usr/sbin/edge -l localhost:1200 -c Vultr -a 192.168.1.1 -k mypassword -f

[Install]
WantedBy=multi-user.target

I denna servicefil definierade vi följande kommandoradsalternativ:

  • -l localhost:1200: Detta kommer att ansluta till localhost på UDP-porten 1200.
  • -c Vultr: Det här är gemenskapen som kanten kommer att gå med i. Alla kanter inom samma community visas på samma LAN (lager 2 nätverkssegment). Kanter som inte finns i samma community kommer inte att kommunicera med varandra.
  • -a 192.168.1.1: IP-adressen som tilldelats detta gränssnitt. Detta är den N2N virtuella LAN IP-adressen som görs anspråk på.
  • -k mypassword: Lösenordet som används för varje kant. Alla kanter som kommunicerar måste använda samma nyckel och gruppnamn.
  • -f: Inaktiverar demonläget och gör att edge körs i förgrunden. Detta behövs för tjänstefilen, annars systemctlstartar inte tjänsten.

Starta tjänsten för att säkerställa att allt fungerar.

systemctl start n2n_edge

Fråga sedan tjänstens status.

systemctl status n2n_edge   

Utgången kommer att likna följande.

● n2n_edge.service - n2n edge
   Loaded: loaded (/etc/systemd/system/n2n_edge.service; disabled; vendor preset: en
   Active: active (running) since Wed 2018-08-15 17:10:46 UTC; 3s ago
 Main PID: 4776 (edge)
    Tasks: 1
   Memory: 396.0K
      CPU: 8ms
   CGroup: /system.slice/n2n_edge.service
           └─4776 /usr/sbin/edge -l localhost:1200 -c Vultr -a 192.168.1.1 -k mypass

Om vi ​​markerar 'ifconfig' kommer du att se den virtuella N2N IP-adressen som görs anspråk på av edge0gränssnittet.

ifconfig

Utgången kommer att likna följande.

edge0     Link encap:Ethernet  HWaddr 42:14:55:64:7d:21
          inet addr:192.168.1.1  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::4014:55ff:fe64:7d21/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1400  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 (0.0 B)  TX bytes:648 (648.0 B)

När detta är gjort, aktivera och skapa brandväggsreglerna. Se till att ersätta node_miami_ipoch node_sydney_iptext med den publika IP i Sydney och Miami instans. (Vi kommer att använda dessa senare).

ufw allow 22/tcp
ufw allow from node_miami_ip to any port 1200
ufw allow from node_sydney_ip to any port 1200
ufw enable

Det sista att göra med denna nod är att aktivera båda tjänsterna vid uppstart.

systemctl enable n2n_supernode.service
systemctl enable n2n_edge.service

Installation - Node Miami

Miami-noden kommer att ansluta till supernoden som för närvarande körs i Paris-zonen. För att uppnå detta behöver vi bara skapa en servicefil för edgeapplikationen.

Börja med att skapa en edge servicefil.

nano /etc/systemd/system/n2n_edge.service

Lägg till följande innehåll.

[Unit]
Description=n2n edge
Wants=network-online.target
After=network-online.target

[Service]
ExecStart=/usr/sbin/edge -l node_paris_ip:1200 -c Vultr -a 192.168.1.2 -k mypassword -f

[Install]
WantedBy=multi-user.target

Obs : Ersätt node_paris_ipmed den offentliga IP-adressen för instansen som körs i Paris

Detta kommer att ansluta till noden i Paris på UDP-porten 1200, gå med i communityn ' Vultr', göra anspråk på IP 192.168.1.2och autentisera med ' mypassword'.

Starta sedan tjänsten.

systemctl start n2n_edge

Kontrollera status för en indikation på att tjänsten har startat korrekt och körs.

systemctl status n2n_edge   

Se sedan till att edge0IP:n görs anspråk på.

ifconfig

Den kommer att visa 192.168.1.2IP-adressen.

edge0     Link encap:Ethernet  HWaddr 42:14:55:64:7d:21
          inet addr:192.168.1.2  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::4014:55ff:fe64:7d21/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1400  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 (0.0 B)  TX bytes:648 (648.0 B)

Nästa sak att göra är att aktivera tjänsten vid uppstart.

systemctl enable n2n_edge.service

Aktivera brandväggen och lägg till SSH-reglerna.

ufw allow 22/tcp
ufw enable

Vi kommer nu att kunna pinga båda kanterna som körs i våra instanser.

I Paris, pinga Vultr-instansen i Miami

ping 192.168.1.2

I Miami, pinga kanten i Paris

ping 192.168.1.1

Installation - Node Sydney

Slutligen kommer vi att lägga till vår sista kontinent i mixen: Australien. Börja igen med att skapa en edge-tjänst, denna edge-tjänst kommer också att ansluta till den tidigare konfigurerade supernoden i Paris.

nano /etc/systemd/system/n2n_edge.service

Lägg till följande innehåll.

[Unit]
Description=n2n edge
Wants=network-online.target
After=network-online.target

[Service]
ExecStart=/usr/sbin/edge -l node_paris_ip:1200 -c Vultr -a 192.168.1.3 -k mypassword -f

[Install]
WantedBy=multi-user.target

Obs : Ersätt node_paris_ipmed den offentliga IP-adressen för instansen som körs i Paris.

Detta kommer att ansluta till noden i Paris på UDP-porten 1200, gå med i communityn ' Vultr', göra anspråk på IP 192.168.1.3och autentisera med ' mypassword'.

systemctl start n2n_edge

Kontrollera statusen för att säkerställa att tjänsten har startat.

systemctl status n2n_edge   

Se till att edge0IP:n görs anspråk på.

edge0     Link encap:Ethernet  HWaddr 46:56:b0:e9:8f:8a
          inet addr:192.168.1.3  Bcast:192.168.1.255  Mask:255.255.255.0
        inet6 addr: fe80::4456:b0ff:fee9:8f8a/64 Scope:Link
        UP BROADCAST RUNNING MULTICAST  MTU:1400  Metric:1
        RX packets:0 errors:0 dropped:0 overruns:0 frame:0
        TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
        collisions:0 txqueuelen:1000
        RX bytes:0 (0.0 B)  TX bytes:648 (648.0 B)

Återigen, aktivera den här tjänsten vid uppstart.

systemctl enable n2n_edge.service

Aktivera brandväggen och lägg till SSH-reglerna.

ufw allow 22/tcp
ufw enable

Vi kommer nu att kunna pinga varje Vultr-instans från varje nod.

ping 192.168.1.1
ping 192.168.1.2
ping 192.168.1.3

Om du vill testa kopplingen mellan varje nodkant, aktivera brandväggsreglerna för instanserna Miami och Paris. Detta kommer att möjliggöra kommunikation mellan kanterna.

I Miami, lägg till följande regler. (Se till att ersätta node_paris_ipoch node_sydney_iptext med de offentliga IP-adresser i Sydney och Paris instanser.)

ufw allow from node_paris_ip to any port 1200
ufw allow from node_sydney_ip to any port 1200

Lägg till följande regler i Sydney.

ufw allow from node_paris_ip to any port 1200
ufw allow from node_miami_ip to any port 1200

Nu kan du stänga av eller starta om supernoden. Nätverksanslutningar kommer att fortsätta att finnas. Endast nya kanter kommer att drabbas av anslutningsproblem medan supernodtjänsten är nere.

Slutsats

Vi har framgångsrikt konfigurerat en VPN-anslutning mellan flera zoner. Detta bör erbjuda en hel del nya möjligheter för scenarier med hög tillgänglighet till vår nykonfigurerade miljö.


Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

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

Installera Lets Encrypt SSL på One-Click WordPress-appen

Installera Lets Encrypt SSL på One-Click WordPress-appen

Introduktion Lets Encrypt är en certifikatmyndighetstjänst som erbjuder gratis TLS/SSL-certifikat. Installationsprocessen förenklas av Certbot,

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Använder du ett annat system? Vad är Tekkit Classic? Tekkit Classic är ett modpack för spelet som alla känner och älskar; Minecraft. Den innehåller några av ver

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

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

PHP och relaterade paket är de mest använda komponenterna när du distribuerar en webbserver. I den här artikeln kommer vi att lära oss hur du ställer in PHP 7.0 eller PHP 7.1 o

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Tre gratis serverkontrollpaneler (snabbinstallation)

Tre gratis serverkontrollpaneler (snabbinstallation)

1. Virtualmin/Webmin Virtualmin är en kraftfull och flexibel kontrollpanel för webbhotell för Linux- och UNIX-system baserad på den välkända Open Source-webbasen

Konfigurera en Yii-applikation på Ubuntu 14.04

Konfigurera en Yii-applikation på Ubuntu 14.04

Yii är ett PHP-ramverk som låter dig utveckla applikationer snabbare och enklare. Att installera Yii på Ubuntu är enkelt, eftersom du kommer att lära dig exakt

Använder skärmen på Ubuntu 14.04

Använder skärmen på Ubuntu 14.04

Screen är ett program som tillåter flera terminalsessioner inom ett fönster. Detta låter dig simulera flera terminalfönster där det ma

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

Använda Logrotate för att hantera loggfiler

Använda Logrotate för att hantera loggfiler

Inledning Logrotate är ett Linux-verktyg som förenklar administrationen av loggfiler. Den körs vanligtvis en gång om dagen via ett cron-jobb och hanterar loggbasen

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Konfigurera Red5 Media Server på Ubuntu 16.04

Konfigurera Red5 Media Server på Ubuntu 16.04

Använder du ett annat system? Red5 är en mediaserver med öppen källkod implementerad i Java som låter dig köra Flash fleranvändarapplikationer som livestreamin

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 Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Hur man installerar Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Vanilla Forum på Ubuntu 16.04

Hur man installerar Vanilla Forum på Ubuntu 16.04

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

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