Configure sua própria rede privada com o OpenVPN
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
AnyConnect é uma solução de acesso remoto desenvolvida pela Cisco. Conhecido por sua portabilidade e estabilidade, especialmente sua capacidade DTLS, o AnyConnect é usado por muitas empresas. Vamos usar uma versão de código aberto ocserv
compatível com o protocolo.
Também vamos implantar a verificação de certificado. O servidor identificará os clientes, verificando se o certificado do cliente é emitido pela CA configurada. Isso simplifica bastante a configuração dos clientes, pois precisamos apenas importar o certificado no cliente (na maioria das vezes um arquivo pkcs12 ( .pfx
ou .p12
)) e nenhuma senha é necessária. Isso também é mais seguro, já que nenhuma senha viaja pela Internet.
Vamos começar.
Notas:
Embora seja possível (e bastante conveniente) fazer tudo no servidor, o processo de implantação consiste em gerar chaves privadas usadas para assinatura e devido a questões de segurança, esse processo deve ser feito no seu próprio computador.
Devido a problemas de licenciamento, não fornecerei links para baixar o software cliente. Encontrá-los para o seu cliente é bastante fácil. O AnyConnect é um aplicativo nas App Stores nas principais plataformas móveis (iOS, Android, BlackBerry OS (v10 ou superior), UWP), respectivamente, e uma simples pesquisa os levará até você. Para plataformas de PC, alguns usuários do Google apresentam o software adequado.
As máquinas CentOS 7 do Vultr são configuradas com o repositório EPEL. Acabamos de instalar ocserv
com yum
:
yum update
yum install ocserv
Precisamos de um certificado de servidor para que as coisas funcionem. Se você tiver um nome de domínio, o Let's Encrypt será a escolha mais fácil.
yum install certbot
certbot certonly
Escolha "ativar um servidor da Web temporário" para autenticar com a ACME CA. Se você não possui um domínio, um certificado autoassinado será emitido posteriormente.
A PKI tradicional é bastante inconveniente de usar, portanto, usaremos o easyrsa
utilitário do projeto OpenVPN. Instale o git na sua máquina de trabalho e clone o repositório:
git clone https://github.com/OpenVPN/easy-rsa
cd easy-rsa/easyrsa3
Criaremos a CA e emitiremos certificados. Faça o seguinte e escreva a senha do PEM que você definiu em algum lugar:
./easyrsa init-pki
./easyrsa build-ca
Mantenha em pki/private/ca.key
algum lugar seguro. Vazamentos que tornarão toda a sua infraestrutura inútil.
Se você optar por usar um certificado de servidor autoassinado, faça o seguinte:
./easyrsa gen-req server
E insira o endereço IP do seu servidor como o nome comum.
./easyrsa sign-req server server
Isso assinará um certificado para o servidor. Transfira pki/issued/server.crt
e pki/ca.crt
para /etc/ssl/certs
e pki/private/server.key
para o /etc/ssl/private
seu servidor.
Em seguida, criaremos certificados de cliente. Faça o seguinte:
./easyrsa gen-req client_01
./easyrsa sign-req client client_01
Escolha um nome do cliente e preencha-o no campo de nome comum. Lembre-se da frase secreta!
Em seguida, exportaremos o certificado no formato pkcs12 para uso em plataformas móveis. Faz:
./easyrsa export-p12 client_01
Escolha uma senha de exportação que você será solicitado a digitar ao importar o certificado no telefone. Transfira pki/private/client_01.p12
para o seu telefone e importe-o.
Nós preencheremos as informações do certificado.
vim /etc/ocserv/ocserv.conf
Localize a server-cert
seção e preencha o seguinte:
# 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
Observe que, se você estiver usando um certificado autoassinado, lembre-se de remover a frase secreta primeiro openssl rsa -in server.key -out server-new.key
para que ocserv
possa usar a chave privada.
Localize a auth
seção. Ative esta linha:
auth = "certificate"
E comente todas as outras auth
linhas.
Remova o comentário desta linha:
cert-user-oid = 2.5.4.3
Localize ipv6-network
e preencha o bloco ipv6 do seu servidor. Esse é o bloco do qual o servidor concederá concessões.
ipv6-network = 2001:0db8:0123:4567::/64
ipv6-subnet-prefix = 124
Defina servidores DNS.
dns = 8.8.8.8
dns = 8.8.4.4
Habilite a compatibilidade com clientes Cisco.
cisco-client-compat = true
Abrir as portas definidas no tcp-port
e udp-port
e permitir mascarada tanto para IPv4 e IPv6 em firewalld.
Inicie o servidor.
systemctl enable ocserv
systemctl start ocserv
O servidor foi configurado com sucesso. Crie uma conexão no seu cliente e conecte-se. Se tudo der errado, use este comando para depurar:
journalctl -fu ocserv
Além disso, o IPv6 deve funcionar no lado do cliente, se o software do cliente suportar o ipv6, mesmo que a rede do cliente não forneça um endereço. Vá para este site para testar.
Tudo pronto! Aproveite o seu novo servidor VPN compatível com AnyConnect!
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi
Usando um sistema diferente? O ESpeak pode gerar arquivos de áudio de conversão de texto em fala (TTS). Isso pode ser útil por vários motivos, como criar seu próprio Turim
Usando um sistema diferente? O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa o SNMP para obter os dados de diferentes dispositivos. Uma variedade
Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud
Usando um sistema diferente? O RabbitMQ é um intermediário de mensagens de código aberto amplamente usado, escrito na linguagem de programação Erlang. Como um middleware orientado a mensagens
Usando um sistema diferente? O RTMP é ótimo para veicular conteúdo ao vivo. Quando o RTMP é emparelhado com o FFmpeg, os fluxos podem ser convertidos em várias qualidades. Vultr i
Usando um sistema diferente? Gradle é um conjunto de ferramentas de automação de compilação de código aberto e gratuito baseado nos conceitos do Apache Ant e Apache Maven. Gradle fornece
Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.
Usando um sistema diferente? O Netdata é uma estrela em ascensão no campo do monitoramento de métricas do sistema em tempo real. Comparado com outras ferramentas do mesmo tipo, o Netdata:
Usando um sistema diferente? O Apache Cassandra é um sistema de gerenciamento de banco de dados NoSQL gratuito e de código aberto, projetado para fornecer escalabilidade, alta
Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos
Usando um sistema diferente? Neste tutorial, explicarei como configurar um servidor Starbound no CentOS 7. Pré-requisitos Você precisa ser o proprietário deste jogo
O ZNC é um segurança IRC gratuito e de código aberto que permanece permanentemente conectado a uma rede para que os clientes possam receber mensagens enviadas enquanto estiverem offline. Thi
O Django é uma estrutura Python popular para escrever aplicativos da web. Com o Django, você pode criar aplicativos mais rapidamente, sem reinventar a roda. Se você quiser você
Outubro é um sistema de gerenciamento de conteúdo de código aberto baseado no Laravel PHP Framework. Com uma interface elegante e uma arquitetura modular concisa
Após alterar a porta SSH, configurar a batida na porta e fazer outros ajustes para a segurança SSH, talvez haja mais uma maneira de protegê-lo
Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL
Usando um sistema diferente? O Directus 6.4 CMS é um sistema de gerenciamento de conteúdo sem cabeça (CMS) poderoso e flexível, gratuito e de código aberto que fornece
Usando um sistema diferente? O Reader Self 3.5 é um leitor de RSS auto-hospedado, simples e flexível, gratuito e de código aberto, e uma alternativa ao Google Reader. Leitor Sel
Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane
ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.
O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+
Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.
Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais
13 Ferramentas de Extração de Dados Comerciais de Big Data
Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true
À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.
Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1
A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA na área da saúde ainda está crescendo dia a dia.