Introducción
WireGuard es una tecnología moderna de red privada virtual (VPN) con cifrado de última generación. En comparación con otras soluciones similares, como IPsec y OpenVPN, WireGuard es más rápido, más fácil de configurar y tiene más rendimiento. Es multiplataforma y puede ejecutarse prácticamente en cualquier lugar, incluidos Linux, Windows, Android y macOS. Wireguard es una VPN de igual a igual; no utiliza el modelo cliente-servidor. Dependiendo de su configuración, un par puede actuar como un servidor o cliente tradicional.
WireGuard funciona creando una interfaz de red en cada dispositivo del mismo nivel que actúa como un túnel. Los pares se autentican intercambiando y validando claves públicas, imitando el modelo SSH. Las claves públicas se asignan a una lista de direcciones IP permitidas en el túnel. El tráfico de VPN está encapsulado en UDP.
En este tutorial, instalaremos WireGuard en una máquina Ubuntu 18.04 que actuará como servidor VPN. También le mostraremos cómo configurar WireGuard como cliente. El tráfico del cliente se enrutará a través del servidor Ubuntu 18.04.
Esta configuración se puede utilizar como protección contra los ataques Man in the Middle, navegar en la web de forma anónima, ignorar el contenido restringido geográficamente o permitir que los colegas se conecten de forma segura a la red corporativa cuando trabajan de forma remota.
Prerrequisitos
Necesitará un servidor Ubuntu 18.04 en el que pueda iniciar sesión como root o cuenta con privilegios sudo.
Instale el servidor WireGuard
En esta sección, instalaremos WireGuard en la computadora Ubuntu y lo configuraremos para que actúe como servidor. También configuraremos el sistema para enrutar el tráfico del cliente a través de él.
Instale WireGuard en Ubuntu 18.04
WireGuard mantiene su propio repositorio APT desde el cual instalaremos el paquete y lo actualizaremos cuando haya una nueva versión disponible.
Actualice la lista de paquetes e instale las herramientas necesarias para administrar los repositorios de su sistema. Es probable que ya tenga el paquete en su máquina:
sudo apt update
sudo apt install software-properties-common
Agregue el repositorio WireGuard:
sudo add-apt-repository ppa:wireguard/wireguard
Cuando se le solicite, presione Enter
para continuar. add-apt-repository
también actualizará automáticamente la lista de paquetes.
Instale el paquete WireGuard:
sudo apt install wireguard
Actualice o instale los encabezados del kernel con el siguiente comando:
sudo apt install linux-headers-$(uname -r)
WireGuard funciona como un módulo del kernel, que se compila como un módulo DKMS. Si tiene éxito, verá el siguiente resultado:
wireguard:
Running module version sanity check.
- Original module
- No original module exists within this kernel
- Installation
- Installing to /lib/modules/4.15.0-88-generic/updates/dkms/depmod...
DKMS: install completed.
Cuando actualice el kernel, el módulo WireGuard se compilará en el nuevo kernel.
Configurar WireGuard
WireGuard viene con dos herramientas de línea de comando llamadas wg
y wg-quick
que le permiten configurar y administrar interfaces WireGuard.
Ejecute el siguiente comando para generar las claves públicas y privadas:
wg genkey | sudo tee /etc/wireguard/privatekey | wg pubkey | sudo tee /etc/wireguard/publickey
Los archivos se generarán en el directorio /etc/wireguard
Puede ver archivos con cat
o less
. La clave privada nunca debe compartirse con nadie.
Ahora que se generan las claves, necesitaremos configurar el dispositivo de túnel que enrutará el tráfico VPN.
El dispositivo se puede configurar desde la línea de comando usando ip
y wg
o creando el archivo de configuración con un editor de texto.
Cree un nuevo archivo llamado wg0.conf
y agregue el siguiente contenido:
sudo nano /etc/wireguard/wg0.conf
La interfaz se puede nombrar como cualquiera, sin embargo, se recomienda usar algo como include wg0
o wgvpn0
. Los ajustes en la sección de interfaz tienen el siguiente significado:
- Dirección: una lista separada por comas de direcciones IP v4 o v6 para la interfaz
wg0
Utilice IP de un rango reservado para redes privadas (10.0.0.0/8, 172.16.0.0/12 o 192.168.0.0/16). - ListenPort: el puerto en el que WireGuard aceptará conexiones entrantes.
- PrivateKey: una clave privada generada por el comando
wg genkey
(Para ver el contenido del archivo, ejecute:sudo cat /etc/wireguard/privatekey
) - SaveConfig: si se establece en verdadero, el estado actual de la interfaz se guarda en el archivo de configuración al apagar.
- PostUp: comando o script que se ejecuta antes de abrir la interfaz. En este ejemplo, usamos iptables para habilitar el enmascaramiento. Esto permitirá que el tráfico salga del servidor, dando acceso a Internet a los clientes VPN. Asegúrese de reemplazar
ens3
después de-A POSTROUTING
para que coincida con el nombre de su interfaz de red pública. Puede encontrar fácilmente la interfaz ejecutando el siguiente comando:
ip -o -4 route show to default | awk '{print $5}'
- PostDown: comando o script que se ejecuta antes de deshabilitar la interfaz. Las reglas de iptables se eliminarán cuando la interfaz esté inactiva.
Los wg0.conf
y privatekey
no deben ser legibles por usuarios normales. Use chmod
para establecer los permisos en 600
:
sudo chmod 600 /etc/wireguard/{privatekey,wg0.conf}
Una vez hecho esto, abra la wg0
usando los atributos especificados en el archivo de configuración:
sudo wg-quick up wg0
El comando producirá un resultado similar al siguiente:
[#] ip link add wg0 type wireguard
[#] wg setconf wg0 /dev/fd/63
[#] ip -4 address add 10.0.0.1/24 dev wg0
[#] ip link set mtu 1420 up dev wg0
[#] iptables -A FORWARD -i wg0 -j ACCEPT; iptables -t nat -A POSTROUTING -o ens3 -j MASQUERADE
Ejecute wg show wg0
para verificar el estado y la configuración de la interfaz:
sudo wg show wg0
interface: wg0
public key: r3imyh3MCYggaZACmkx+CxlD6uAmICI8pe/PGq8+qCg=
private key: (hidden)
listening port: 51820
También puede ejecutar ip a show wg0
para verificar el estado de la interfaz:
ip a show wg0
4: wg0: <POINTOPOINT,NOARP,UP,LOWER_UP> mtu 1420 qdisc noqueue state UNKNOWN group default qlen 1000
link/none
inet 10.0.0.1/24 scope global wg0
valid_lft forever preferred_lft forever
Para que la interfaz WireGuard se inicie, ejecute el siguiente comando:
sudo systemctl enable wg-quick@wg0
Configuración de firewall y red del servidor
Para que NAT funcione, el reenvío de IP debe estar habilitado. Abra el /etc/sysctl.conf
y agregue o descomente la siguiente línea:
sudo nano /etc/sysctl.conf
net.ipv4.ip_forward=1
Guarde el archivo y aplique el cambio:
sudo sysctl -p
net.ipv4.ip_forward = 1
Si está utilizando UFW para administrar su firewall, debe abrir el tráfico UDP en el puerto 51820
:
sudo ufw allow 51820/udp
Eso es todo. Se ha configurado el par de Ubuntu que actuará como servidor.
Instale el cliente Linux y macOS
Las instrucciones de instalación para todas las plataformas compatibles están disponibles en https://wireguard.com/install/. En sistemas Linux, puede instalar el paquete utilizando el administrador de paquetes de distribución y en macOS con brew
. Una vez que WireGuard esté instalado, siga los pasos a continuación para configurar el dispositivo cliente.
El proceso para configurar un cliente de Linux y macOS es prácticamente el mismo que hizo para el servidor. Comience generando las claves públicas y privadas:
wg genkey | sudo tee /etc/wireguard/privatekey | wg pubkey | sudo tee /etc/wireguard/publickey
Cree el wg0.conf
y agregue el siguiente contenido:
sudo nano /etc/wireguard/wg0.conf
[Interface]
PrivateKey = CLIENT_PRIVATE_KEY
Address = 10.0.0.2/24
[Peer]
PublicKey = SERVER_PUBLIC_KEY
Endpoint = SERVER_IP_ADDRESS:51820
AllowedIPs = 0.0.0.0/0
Los ajustes en la sección de interfaz tienen el mismo significado que al configurar el servidor:
- Dirección: una lista separada por comas de direcciones IP v4 o v6 para la interfaz
wg0
- PrivateKey: para ver el contenido del archivo en la computadora cliente en ejecución:
sudo cat /etc/wireguard/privatekey
.
La sección de pares contiene los siguientes campos:
- PublicKey: una clave pública del par al que desea conectarse. (El contenido del
/etc/wireguard/publickey
- Punto final: una IP o nombre de host del par al que desea conectarse seguido de dos puntos, luego un número de puerto en el que escucha el par remoto.
- AllowIPs: una lista separada por comas de direcciones IP v4 o v6 desde las que se permite el tráfico entrante para este par y a las que se enruta el tráfico saliente para este par. Estamos usando
0.0.0.0/0
porque estamos enrutando el tráfico y queremos que el servidor del mismo nivel envíe paquetes con cualquier IP de origen.
Si necesita configurar clientes adicionales, repita los mismos pasos con una dirección IP privada diferente.
Instalar el cliente de Windows
Descargue e instale el paquete msi de Windows desde el sitio web de WireGuard.
Una vez instalado, abra la aplicación WireGuard y haga clic en "Agregar túnel" -> "Agregar túnel vacío...".
Se crea automáticamente un par de claves públicas y se muestra en la pantalla.
Ingrese un nombre para el túnel y cambie la configuración de la siguiente manera:
[Interface]
PrivateKey = CLIENT_PRIVATE_KEY
Address = 10.0.0.2/24
[Peer]
PublicKey = SERVER_PUBLIC_KEY
Endpoint = SERVER_IP_ADDRESS:51820
AllowedIPs = 0.0.0.0/0
En la sección de interfaz, agregue una nueva línea para definir la dirección del túnel del cliente.
En la sección de pares, agregue los siguientes campos:
- PublicKey: la clave pública del servidor Ubuntu (archivo
/etc/wireguard/publickey
). - Punto final: dirección IP del servidor Ubuntu seguida de dos puntos y el puerto WireGuard (51820).
- IP permitidas -
0.0.0.0/0
Una vez hecho esto, haga clic en el botón "Guardar".
Agregue el cliente par al servidor
El último paso es agregar la clave pública y la dirección IP del cliente al servidor:
sudo wg set wg0 peer CLIENT_PUBLIC_KEY allowed-ips 10.0.0.2
Asegúrese de cambiar el CLIENT_PUBLIC_KEY
a la clave pública que generó en la computadora cliente ( sudo cat /etc/wireguard/publickey
) y ajuste la dirección IP del cliente si es diferente. Los usuarios de Windows pueden copiar la clave pública de la aplicación WireGuard.
Una vez hecho esto, regrese a la computadora cliente y vea la interfaz de túnel.
Cliente Linux y macOS
En clientes Linux, ejecute el siguiente comando para abrir la interfaz:
sudo wg-quick up wg0
Ahora debería estar conectado al servidor Ubuntu y el tráfico de su computadora cliente debería enrutarse a través de él. Puedes comprobar la conexión con:
sudo wg
interface: wg0
public key: sZThYo/0oECwzUsIKTa6LYXLhk+Jb/nqK4kCCP2pyFg=
private key: (hidden)
listening port: 48052
fwmark: 0xca6c
peer: r3imyh3MCYggaZACmkx+CxlD6uAmICI8pe/PGq8+qCg=
endpoint: XXX.XXX.XXX.XXX:51820
allowed ips: 0.0.0.0/0
latest handshake: 1 minute, 22 seconds ago
transfer: 58.43 KiB received, 70.82 KiB sent
También puede abrir su navegador, escribir "cuál es mi ip" y debería ver la dirección IP de su servidor Ubuntu.
Para detener el túnel, cierre la wg0
con el siguiente comando:
sudo wg-quick down wg0
Cliente de Windows
Si ha instalado WireGuard en Windows, haga clic en el botón " Activar ". Una vez que los pares están conectados, el estado del túnel cambiará a Activo.
Conclusión
Le mostramos cómo instalar WireGuard en una máquina Ubuntu 18.04 y configurarlo como un servidor VPN. Esta configuración le permite navegar por la web de forma anónima mientras mantiene la privacidad de sus datos de tráfico.