Implementació del servidor VPN compatible amb AnyConnect amb verificació de certificat a CentOS 7

AnyConnect és una solució d'accés remot desenvolupada per Cisco. Conegut per la seva portabilitat i estabilitat, especialment per la seva capacitat DTLS, AnyConnect és utilitzat per moltes empreses. Utilitzarem una versió de codi obert, ocserv, que és compatible amb el protocol.

També implementarem la verificació del certificat. El servidor identificarà els clients comprovant que si el certificat del client és emès per la CA configurada. Això simplifica molt la configuració dels clients, ja que només haurem d'importar el certificat al client (la majoria de vegades un fitxer pkcs12 ( .pfxo .p12)) i no calen contrasenyes. Això també és més segur ja que cap contrasenya no viatja per Internet.

Comencem.

Requisits previs

  • Un servidor CentOS 7 de nova creació amb IPv6 habilitat
  • Un ordinador que funcioni (pot ser el propi servidor; però obsolet (vegeu més avall)) vegeu la nota 1
  • Alguns clients amb programari client AnyConnect (o OpenConnect) instal·lat, vegeu la nota 2

Notes:

  1. Tot i que és possible (i més aviat convenient) fer-ho tot al servidor, el procés de desplegament consisteix a generar claus privades utilitzades per a la signatura i, per problemes de seguretat, aquest procés s'ha de fer al vostre ordinador.

  2. A causa de problemes de llicència, no proporcionaré enllaços per descarregar el programari del client. Tanmateix, trobar-los per al vostre client és bastant fàcil. AnyConnect és una aplicació a les botigues d'aplicacions a les principals plataformes mòbils (iOS, Android, BlackBerry OS (v10 o superior), UWP) respectivament i una simple cerca us els portarà. Per a les plataformes de PC, alguns Google us presentaran el programari adequat.

Instal·lació de programari al costat del servidor

Les màquines CentOS 7 de Vultr estan configurades amb el repositori EPEL. Només instal·lem ocservamb yum:

yum update
yum install ocserv

Necessitarem un certificat de servidor perquè les coses funcionin. Si teniu un nom de domini, Let's Encrypt serà l'opció més fàcil.

yum install certbot
certbot certonly

Trieu "engegar un servidor web temporal" per autenticar-vos amb ACME CA. Si no teniu un domini, més endavant s'emetrà un certificat autofirmat.

Generació i configuració de certificats

La PKI tradicional és bastant incòmode d'utilitzar, de manera que farem servir la easyrsautilitat del projecte OpenVPN. Instal·leu git a la vostra màquina de treball i cloneu el repositori:

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

Construirem la CA i emetrem certificats. Feu el següent i escriviu la contrasenya PEM que hàgiu establert en algun lloc:

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

Mantingueu-vos pki/private/ca.keyen un lloc segur. Fuga que farà que tota la vostra infraestructura sigui inútil.

Si trieu utilitzar un certificat de servidor autofirmat, feu el següent:

./easyrsa gen-req server

I introduïu l'adreça IP del vostre servidor com a nom comú.

./easyrsa sign-req server server

Això signarà un certificat per al servidor. Transferiu pki/issued/server.crti cap pki/ca.crta /etc/ssl/certsi pki/private/server.keycap /etc/ssl/privateal vostre servidor.

A continuació, crearem certificats de client. Feu el següent:

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

Trieu un nom del client i ompliu-lo al camp del nom comú. Recordeu la contrasenya!

A continuació, exportarem el certificat en format pkcs12 per utilitzar-lo en plataformes mòbils. Fes:

./easyrsa export-p12 client_01

Trieu una contrasenya d'exportació que se us demanarà que introduïu quan importeu el certificat al telèfon. Transferiu pki/private/client_01.p12-lo al vostre telèfon i importeu-lo.

Configuració del servidor

Omplirem la informació del certificat.

vim /etc/ocserv/ocserv.conf

Localitza la server-certsecció i omple el següent:

# 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

Tingueu en compte que si feu servir un certificat autofirmat, recordeu d'eliminar primer la frase de contrasenya openssl rsa -in server.key -out server-new.keyperquè ocservpugueu utilitzar la clau privada.

Localitza la authsecció. Activa aquesta línia:

auth = "certificate"

I comenta totes les altres authlínies.

Descomenteu aquesta línia:

cert-user-oid = 2.5.4.3

Localitzeu ipv6-networki ompliu el bloc ipv6 del vostre servidor. Aquest és el bloc des del qual el servidor donarà contractes d'arrendament.

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

Configura els servidors DNS.

dns = 8.8.8.8
dns = 8.8.4.4

Habiliteu la compatibilitat amb els clients de Cisco.

cisco-client-compat = true

Obrir els ports que estableixi en tcp-porti udp-porti permetre mascarada per IPv4 i IPv6 en firewalld.

Inicieu el servidor.

systemctl enable ocserv
systemctl start ocserv

Temps de prova!

El servidor s'ha configurat correctament. Creeu una connexió al vostre client i connecteu-vos. Si les coses van malament, utilitzeu aquesta ordre per depurar:

journalctl -fu ocserv

A més, IPv6 hauria de funcionar al costat del client si el programari del vostre client admet ipv6 encara que la xarxa del vostre client no us proporcioni una adreça. Aneu a aquest lloc per provar.

Llest! Gaudeix del teu nou servidor VPN compatible amb AnyConnect!


Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Microweber a CentOS 7

Com instal·lar Microweber a CentOS 7

Utilitzeu un sistema diferent? Microweber és un CMS d'arrossegar i deixar anar de codi obert i una botiga en línia. El codi font de Microweber està allotjat a GitHub. Aquesta guia us mostrarà

Com instal·lar Vanilla Forum a CentOS 7

Com instal·lar Vanilla Forum a CentOS 7

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

Com instal·lar Mattermost 4.1 a CentOS 7

Com instal·lar Mattermost 4.1 a CentOS 7

Utilitzeu un sistema diferent? Mattermost és una alternativa autoallotjada de codi obert al servei de missatgeria Slack SAAS. En altres paraules, amb Mattermost, ca

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Què necessitareu Un Vultr VPS amb almenys 1 GB de RAM. Accés SSH (amb privilegis d'arrel/administrador). Pas 1: instal·lació de BungeeCord Primer de tot

Permet xifrar a Plesk

Permet xifrar a Plesk

El tauler de control de Plesk inclou una integració molt agradable per Lets Encrypt. Lets Encrypt és un dels únics proveïdors SSL que ofereix certificats complets

Permet xifrar a cPanel

Permet xifrar a cPanel

Lets Encrypt és una autoritat de certificació dedicada a proporcionar certificats SSL de manera gratuïta. cPanel ha creat una integració perfecta perquè tu i el teu client

Com instal·lar Concrete5 a CentOS 7

Com instal·lar Concrete5 a CentOS 7

Utilitzeu un sistema diferent? Concrete5 és un CMS de codi obert que ofereix moltes característiques distintives i útils per ajudar els editors a produir continguts fàcilment i

Com instal·lar el tauler de revisió a CentOS 7

Com instal·lar el tauler de revisió a CentOS 7

Utilitzeu un sistema diferent? Review Board és una eina gratuïta i de codi obert per revisar el codi font, la documentació, les imatges i molts més. És un programari basat en web

Configura lautenticació HTTP amb Nginx a CentOS 7

Configura lautenticació HTTP amb Nginx a CentOS 7

En aquesta guia, aprendràs a configurar l'autenticació HTTP per a un servidor web Nginx que s'executa a CentOS 7. Requisits Per començar, necessitareu el

Com instal·lar GoAccess a CentOS 7

Com instal·lar GoAccess a CentOS 7

Utilitzeu un sistema diferent? GoAccess és un analitzador de registres web de codi obert. Podeu utilitzar-lo per analitzar els registres en temps real al terminal o

Com instal·lar YOURLS a CentOS 7

Com instal·lar YOURLS a CentOS 7

YOURLS (Your Own URL Shortener) és una aplicació d'anàlisi de dades i escurçament d'URL de codi obert. En aquest article, tractarem el procés d'instal·lació

Com instal·lar i configurar ArangoDB a CentOS 7

Com instal·lar i configurar ArangoDB a CentOS 7

Utilitzeu un sistema diferent? Introducció ArangoDB és una base de dades NoSQL de codi obert amb un model de dades flexible per a documents, gràfics i claus-valors. És

Utilitzant Etckeeper per al control de versions de /etc

Utilitzant Etckeeper per al control de versions de /etc

Introducció El directori /etc/ té un paper crític en el funcionament d'un sistema Linux. La raó d'això és perquè gairebé totes les configuracions del sistema

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Molts administradors de sistemes gestionen grans quantitats de servidors. Quan s'hagi d'accedir als fitxers a través de diferents servidors, inicieu sessió a cadascun individualment ca

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació