Uvođenje AnyConnect kompatibilnog VPN poslužitelja s provjerom certifikata na CentOS 7

AnyConnect je rješenje za daljinski pristup koje je razvio Cisco. Dobro poznat po svojoj prenosivosti i stabilnosti, posebno po DTLS sposobnostima, AnyConnect koriste mnoge tvrtke. Koristit ćemo verziju otvorenog koda ocserv, koja je kompatibilna s protokolom.

Također ćemo implementirati provjeru certifikata. Poslužitelj će identificirati klijente provjeravajući da li je klijentov certifikat izdao konfigurirani CA. Ovo uvelike pojednostavljuje konfiguraciju na klijentima jer ćemo samo trebati uvesti certifikat na klijenta (većinu puta pkcs12 datoteku ( .pfxili .p12)) i nisu potrebne lozinke. Ovo je također sigurnije jer nijedna zaporka ne putuje internetom.

Počnimo.

Preduvjeti

  • Novostvoreni CentOS 7 poslužitelj s omogućenim IPv6
  • Računalo koje radi (može biti i sam poslužitelj; zastarjelo je (vidi dolje)) vidi bilješku 1
  • Neki klijenti s instaliranim klijentskim softverom AnyConnect (ili OpenConnect) pogledajte bilješku 2

Bilješke:

  1. Iako je moguće (i prilično zgodno) učiniti sve na poslužitelju, proces postavljanja sastoji se od generiranja privatnih ključeva koji se koriste za potpisivanje, a zbog sigurnosnih razloga, ovaj bi se proces trebao obaviti na vlastitom računalu.

  2. Zbog problema s licenciranjem, neću dati veze za preuzimanje klijentskog softvera. Međutim, prilično je jednostavno pronaći ih za svog klijenta. AnyConnect je aplikacija u App Storeovima na glavnim mobilnim platformama (iOS, Android, BlackBerry OS (v10 ili noviji), UWP) i jednostavno pretraživanje će ih donijeti do vas. Za PC platforme, Google će vam predstaviti odgovarajući softver.

Instalacija softvera na strani poslužitelja

Vultrov CentOS 7 stroj konfiguriran je s EPEL repozitorijom. Samo instaliramo ocservsa yum:

yum update
yum install ocserv

Trebat će nam certifikat poslužitelja da bi stvari funkcionirale. Ako imate naziv domene, Let's Encrypt će biti najlakši izbor.

yum install certbot
certbot certonly

Odaberite "spin up a temporary Web server" za provjeru autentičnosti s ACME CA. Ako nemate domenu, samopotpisani certifikat će biti izdat kasnije.

Generiranje i konfiguracija certifikata

Tradicionalni PKI prilično je nezgodan za korištenje, pa ćemo koristiti easyrsauslužni program iz OpenVPN projekta. Instalirajte git na svoj radni stroj i klonirajte spremište:

git clone https://github.com/OpenVPN/easy-rsa
cd easy-rsa/easyrsa3

Izgradit ćemo CA i izdati certifikate. Učinite sljedeće i napišite PEM pristupnu frazu koju ste negdje postavili:

./easyrsa init-pki
./easyrsa build-ca

Čuvajte pki/private/ca.keynegdje na sigurnom. Curenje koje će cijelu vašu infrastrukturu učiniti beskorisnom.

Ako odlučite koristiti samopotpisani poslužiteljski certifikat, učinite sljedeće:

./easyrsa gen-req server

I unesite IP adresu vašeg poslužitelja kao uobičajeno ime.

./easyrsa sign-req server server

Ovo će potpisati certifikat za poslužitelj. Prebaci pki/issued/server.crta pki/ca.crtda /etc/ssl/certsi pki/private/server.keyda /etc/ssl/privatena vašem poslužitelju.

Zatim ćemo kreirati klijentske certifikate. Učinite sljedeće:

./easyrsa gen-req client_01
./easyrsa sign-req client client_01

Odaberite ime klijenta i popunite ga u polje zajedničkog imena. Zapamtite pristupnu frazu!

Zatim ćemo izvesti certifikat u pkcs12 formatu za korištenje na mobilnim platformama. Čini:

./easyrsa export-p12 client_01

Odaberite lozinku za izvoz koju će od vas biti zatraženo da unesete prilikom uvoza certifikata na telefon. Prenesite pki/private/client_01.p12na svoj telefon i uvezite ga.

Konfiguriranje poslužitelja

Ispunit ćemo podatke o certifikatu.

vim /etc/ocserv/ocserv.conf

Pronađite server-certodjeljak i ispunite sljedeće:

# If you use Let's Encrypt
server-cert = /etc/letsencrypt/live/example.com/fullchain.pem
server-key = /etc/letsencrypt/live/example.com/privkey.pem

# If you use self-signed server certificate 
server-cert = /etc/ssl/certs/server.crt
server-key = /etc/ssl/private/server.key

ca-cert = /etc/ssl/certs/ca.crt

Imajte na umu da ako koristite samopotpisani certifikat, ne zaboravite prvo ukloniti šifru openssl rsa -in server.key -out server-new.keytako da ocservmože koristiti privatni ključ.

Locirajte authodjeljak. Omogući ovu liniju:

auth = "certificate"

I komentirajte sve ostale authretke.

Dekomentiraj ovaj redak:

cert-user-oid = 2.5.4.3

Pronađite ipv6-networki ispunite ipv6 blok vašeg poslužitelja. Ovo je blok iz kojeg će poslužitelj dati zakup.

ipv6-network = 2001:0db8:0123:4567::/64
ipv6-subnet-prefix = 124 

Postavite DNS poslužitelje.

dns = 8.8.8.8
dns = 8.8.4.4

Omogućite kompatibilnost sa Cisco klijentima.

cisco-client-compat = true

Otvoriti portove koje ste postavili na tcp-portte udp-porti omogućiti maskenbal za IPv4 i IPv6 u firewalld.

Pokrenite poslužitelj.

systemctl enable ocserv
systemctl start ocserv

Vrijeme za testiranje!

Poslužitelj je uspješno konfiguriran. Stvorite vezu u svom klijentu i povežite se. Ako stvari krenu krivo, upotrijebite ovu naredbu za otklanjanje pogrešaka:

journalctl -fu ocserv

Također, IPv6 bi trebao raditi na strani klijenta ako vaš klijentski softver podržava ipv6 čak i ako vam mreža vašeg klijenta ne daje adresu. Idite na ovu stranicu za testiranje.

Sve spremno! Uživajte u svom novom AnyConnect kompatibilnom VPN poslužitelju!


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Korištenje drugog sustava? Apache Cassandra je besplatni i otvorenog koda NoSQL sustav upravljanja bazom podataka koji je osmišljen kako bi osigurao skalabilnost, visoku

Kako instalirati Microweber na CentOS 7

Kako instalirati Microweber na CentOS 7

Korištenje drugog sustava? Microweber je CMS i internetska trgovina otvorenog koda povuci i ispusti. Izvorni kod Microwebera nalazi se na GitHubu. Ovaj vodič će vam pokazati

Kako instalirati Mattermost 4.1 na CentOS 7

Kako instalirati Mattermost 4.1 na CentOS 7

Korištenje drugog sustava? Mattermost je open source alternativa Slack SAAS servisu za razmjenu poruka. Drugim riječima, s Mattermostom možete ca

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Što vam treba Vultr VPS s najmanje 1 GB RAM-a. SSH pristup (s root/administrativnim privilegijama). Korak 1: Instalacija BungeeCord-a Najprije

Omogućava šifriranje na Plesku

Omogućava šifriranje na Plesku

Upravljačka ploča Plesk ima vrlo lijepu integraciju za Lets Encrypt. Lets Encrypt je jedan od jedinih SSL pružatelja usluga koji u potpunosti izdaju certifikate

Omogućuje šifriranje na cPanelu

Omogućuje šifriranje na cPanelu

Lets Encrypt je tijelo za izdavanje certifikata posvećeno besplatnom pružanju SSL certifikata. cPanel je izgradio urednu integraciju tako da vi i vaš klijent

Kako instalirati Concrete5 na CentOS 7

Kako instalirati Concrete5 na CentOS 7

Korištenje drugog sustava? Concrete5 je CMS otvorenog koda koji nudi mnoge osebujne i korisne značajke koje pomažu urednicima u jednostavnoj proizvodnji sadržaja i

Kako instalirati ploču za pregled na CentOS 7

Kako instalirati ploču za pregled na CentOS 7

Korištenje drugog sustava? Review Board je besplatan alat otvorenog koda za pregled izvornog koda, dokumentacije, slika i još mnogo toga. To je web-bazirani softver

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

U ovom vodiču naučit ćete kako postaviti HTTP autentifikaciju za Nginx web poslužitelj koji radi na CentOS 7. Zahtjevi Da biste započeli, trebat će vam

Kako instalirati YOURLS na CentOS 7

Kako instalirati YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je aplikacija za skraćivanje URL-ova otvorenog koda i analizu podataka. U ovom članku ćemo pokriti proces instalacije

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Korištenje drugog sustava? Uvod ArangoDB je NoSQL baza podataka otvorenog koda s fleksibilnim modelom podataka za dokumente, grafikone i ključ-vrijednosti. to je

Korištenje Etckeepera za kontrolu verzija /etc

Korištenje Etckeepera za kontrolu verzija /etc

Uvod Direktorij /etc/ igra ključnu ulogu u načinu na koji Linux sustav funkcionira. Razlog tome je što je gotovo svaka konfiguracija sustava

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Mnogi administratori sustava upravljaju velikim količinama poslužitelja. Kada se datotekama treba pristupiti na različitim poslužiteljima, prijava na svaki pojedinačno ca

Postavljanje poslužitelja Half Life 2 na CentOS 6

Postavljanje poslužitelja Half Life 2 na CentOS 6

Ovaj vodič će pokriti proces instaliranja poslužitelja za igre Half Life 2 na sustavu CentOS 6. Korak 1: Instaliranje preduvjeta Kako biste postavili ou

Kako instalirati Laravel GitScrum na CentOS 7

Kako instalirati Laravel GitScrum na CentOS 7

Laravel GitScrum ili GitScrum je alat za produktivnost otvorenog koda dizajniran da pomogne razvojnim timovima da implementiraju Scrum metodologiju na sličan način.

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više