Executando verificação de segurança...
8

Como instalar e configurar o cliente WireGuard no Linux

O WireGuard é uma solução moderna de rede privada virtual (VPN) que se destaca por sua simplicidade, eficiência e segurança. Foi desenvolvido como uma alternativa aos protocolos VPN tradicionais, visando superar limitações em termos de desempenho, facilidade de configuração e segurança.

O intuito dessa artigo é ajudar a instalação no Linux, mas você pode instalar em outro sistema operacional seguindo as instruções deste link.

Instalação do WireGuard Client

Você só vai precisar do seu amigo terminal:

sudo apt install -y wireguard openresolv

Pronto. O artigo poderia acabar aqui hahahaha

Aliases pra facilitar sua vida

Crie os seguintes aliases em seu ~/.bashrc:

alias wgls="sudo ls /etc/wireguard"
alias wgup="sudo wg-quick up ${1}"
alias wgdown="sudo wg-quick down ${1}"

Os aliases acima são opcionais, mas sem eles, você terá que usar os comandos toda vez que quiser conectar ou desconectar da VPN.

Configurando seu cliente

O arquivo de configuração se parece com isso aqui:

[Interface]
Address = 10.1.2.3/24
DNS = 8.8.8.8, 8.8.4.4
PrivateKey = c2Ugdm9jw6ogZXN0w6EgbGVuZG8gaXNzbywgcGFyYWLDqW5zLCB2b2PDqiBzYWJlIHVzYXIgbyBiYXNlNjQgZGVjb2RlIDpECg==

[Peer]
PublicKey = w6ksIG7Do28gdGVtIG5hZGEgZGVtYWlzIHByYSBzZXIgbGlkbyBhcXVpLCBzb3JyeQo=
PresharedKey = c8OpcmlvLCB2b2PDqiB0ZW50b3UgZGVjb2RhciBlc3NlIGFxdWkgdGFtYsOpbT8gUXVlIG1hc3NhIGhhaGFoYWghISBNZSBjb250YSBub3MgY29tZW50w6FyaW9zCg==
AllowedIPs = 0.0.0.0/0, ::/0
Endpoint = 1.2.3.4:51820
PersistentKeepalive = 25

Supondo que você já tem um arquivo de configuração em mãos, que o administrador da VPN já lhe enviou, é hora de salvá-lo no local apropriado.

sudo vim /etc/wireguard/nomedavpn.conf

O nome do arquivo é importante.

O WireGuard utiliza o nome do arquivo de configuração .conf para determinar o nome da interface de rede virtual que será criada. Essa abordagem oferece uma maneira simples e direta de gerenciar várias interfaces VPN.

Neste artigo, vamos considerar que o nome da VPN é infinite, mas se quiser, pode nomear de outra forma.

Entretanto, a interface não pode possuir mais de 15 caracteres, portanto, não use nomes muito longos.

Testando a conexão

  1. Conecte-se com o comando wgup ${vpnName}:

    wgup infinite
    

    Se tudo der certo, você verá uma série de mensagem semelhantes às abaixo:

    [#] ip link add infinite type wireguard
    [#] wg setconf infinite /dev/fd/63
    [#] ip -4 address add 10.1.2.3/24 dev infinite
    [#] ip link set mtu 1420 up dev infinite
    [#] resolvconf -a tun.infinite -m 0 -x
    [#] wg set infinite fwmark 51820
    [#] ip -6 route add ::/0 dev infinite table 51820
    [#] ip -6 rule add not fwmark 51820 table 51820
    [#] ip -6 rule add table main suppress_prefixlength 0
    [#] ip6tables-restore -n
    [#] ip -4 route add 0.0.0.0/0 dev infinite table 51820
    [#] ip -4 rule add not fwmark 51820 table 51820
    [#] ip -4 rule add table main suppress_prefixlength 0
    [#] sysctl -q net.ipv4.conf.all.src_valid_mark=1
    [#] iptables-restore -n
    
  2. Verifique seu IP, para confirmar que você está conectado à VPN:

    curl ifconfig.me
    
  3. Desconecte-se da VPN

    wgdown infinite
    

    Você verá uma saída semelhante à essa:

    [#] ip -4 rule delete table 51820
    [#] ip -4 rule delete table main suppress_prefixlength 0
    [#] ip -6 rule delete table 51820
    [#] ip -6 rule delete table main suppress_prefixlength 0
    [#] ip link delete dev infinite
    [#] resolvconf -d tun.infinite -f
    [#] iptables-restore -n
    [#] ip6tables-restore -n
    

    Seu IP deve ter voltado ao de seu ISP novamente.

VPNs adicionais

Sempre que quiser configurar uma nova VPN WireGuard, tudo que você precisa fazer é salvar o .conf em /etc/wireguard.

Para visualizar seus arquivos de configuração, use o comando wgls, que nada mais é do que um alias que criamos previamente para listar o conteúdo do diretório /etc/wireguard.

Carregando publicação patrocinada...