Entérate primero de nuestras ofertas para webmasters y emprendedores.
No compartiré tu dirección de correo electrónico con los chicos malos.
|
Entérate primero de nuestras ofertas para webmasters y emprendedores. No compartiré tu dirección de correo electrónico con los chicos malos. TwitteringLo último
Comentarios recientes
|
Instalar OpenVPN en Ubuntu, Hulu fuera de los Estados Unidos y seguridad en la Red
Submitted by alexis on Mié, 2008-03-19 14:14.
Hace algunos días escribí sobre Hulu, su restricción para usuarios fuera de los Estados Unidos y como utilizar una red privada virtual (VPN) con un servidor en ese país podía ayudarnos a conectar con el servicio. Pero una VPN no sirve solo para acceder a servicios como Hulu o Pandora (aún cuando fue eso lo que me animó a dedicarle unas horas al tema), es mucho más que eso y es importante que todo aquel que pasa más de la mitad de su vida conectado a la Red (y esos son ustedes, queridos lectores) entienda el concepto. Veamos cómo instalar OpenVPN en Ubuntu Gutsy. Qué es una VPNUna red privada virtual (virtual private network) es una red de comunicaciones canalizada a través de otra red y dedicada a un uso específico. Para nuestro caso esa otra red es Internet. Establecer una VPN que use una red pública como Internet permite eliminar los costos de contratar un enlace dedicado. Pero Internet no es una red segura así que una VPN debe utilizar autenticación y encriptar el contenido que viaja a través de ella para evitar el uso de packet sniffers (software o hardware que puede interceptar el tráfico en una red insegura). Utilizar una VPS puede sonar muy esotérico para muchos pero con el incremento de conexiones WiFi y hotspots inseguros en todo el mundo pronto será una necesidad para todos los que no quieren que su información viaje desnuda por la Red. En el siguiente artículo veremos cómo instalar OpenVPN, una aplicación de código abierto para VPN, en Ubuntu 7.10. Son los pasos que seguí para conectar mis computadoras en Lima con uno de mis servidores en Nueva York y navegar la Red usando su IP. Ahora todos los sitios web y servicios que visito usando OpenVPN detectan mi conexión como si fuera hecha desde los Estados Unidos y todos mis datos viajan seguros. Y aún con más de una decada trabajando con muchos tipos de redes no pretendo ser un experto en TCP/IP y seguridad o que este sea un tratado sobre el tema así que no puedo ofrecer asistencia técnica sobre el tema pero estoy que tendremos a varios especialistas que podrán aportar en los comentarios. Instalar OpenVPN en Ubuntu paso a pasoVale, aquí los pasos que seguí para instalar OpenVPN en un cliente y un servidor, ambos corriendo con Ubuntu 7.10 aunque el procedimiento debe ser muy parecido en otras distribuciones. Gracias a Javier Albarracín, Bruno Kamiche y César Villegas por los tips. Primero definamos algunos puntos:
Lo primero es instalar OpenVPN: sudo apt-get install openvpn OpenVPN se instala tanto en el cliente como en el servidor, el archivo de configuración que usaremos al iniciar OpenVPN más adelante definirá el rol de cada equipo. Ahora comenta todas las líneas en /etc/default/openvpn y añade: AUTOSTART="openvpn" Esto le dice a OpenVPN cuál archivo de configuración predeterminado utilizará al iniciar el servicio. Los archivos de configuración se guardan en /etc/openvpn y usan la extensión .conf por lo que la instrucción de arriba le dice a OpenVPN que use /etc/openvpn/openvpn.conf, es un archivo que aún no existe y que crearemos en un momento. Ahora el servicio OpenVPN puede ser iniciado, detenido o reiniciado en la forma usual, veamos: Iniciar OpenVPN: /etc/init.d/openvpn start Detener OpenVPN: Reiniciar OpenVPN: Cada vez que se cambian parámetros en /etc/openvpn/openvpn.conf se debe reiniciar OpenVPN. Crear claves y certificadosPero antes de continuar crearemos los certificados y claves de seguridad. Todo esto se hace en el servidor como root. Ejecuta: cd /etc/openvpn/ Y ahora copia el directorio easy-rsa a /etc/openvpn: cp -r /usr/share/doc/openvpn/examples/easy-rsa/ . Recuerda que seguimos en el directorio /etc/openvpn. Ahora editaré el archivo vars con nuestro editor favorito (reemplaza vi con el que tú prefieras): vi easy-rsa/vars Comenta esta línea: #export D=`pwd` Añade esta: Y modifica los siguientes parámetros: export KEY_COUNTRY=PE Graba y cierra el archivo. Ahora ejecuta: . ./vars Importante, eso es un punto, un espacio y luego otro punto y seguido por /vars. Muchos lo olvidan. A continuación: El siguiente comando crea la autoridad de certificados (CA) usando los parámetros arriba definidos, solo deberás añadir Common Name, yo usé OpenVPN-CA. Este paso usa OpenSSL y si no lo tenías en tu servidor deberás instalarlo primero con: sudo apt-get install openssl Ahora sí: ./build-ca Ahora creamos las claves, primero para el servidor: ./build-key-server server Esta parte es muy importante. Cuando build-key-server te solicite Common Name escribe server, el mismo parámetro que le diste al comando. Hay dos preguntas más: Sign the certificate? [y/n] y 1 out of 1 certificate requests certified, commit? [y/n], responde afirmativamente en ambos casos. Y ahora la clave para el cliente: ./build-key client1 Recuerda usar client1 como Common Name, al igual que el parámetro que usaste para build-key. Si vas a tener más clientes puedes repetir este último paso para client2, client3, etc. Ahora genera parámetros Diffie Hellman: ./build-dh Ahora debes tener un nuevo directorio con claves y certificados en tu servidor: /etc/openvpn/easy-rsa/keys. Para configurar tu primer cliente copia los siguientes archivos de servo a cliento: ca.crt Lo ideal es usar un canal seguro, yo prefiero scp con autenticación RSA (tema para otro artículo), ejecutando algo como esto en el cliente: scp alexis@servo:ca.crt . Estos comandos asumen que copiaste los archivos al directorio personal del usuario alexis en el servidor y les asignaste permisos de lectura. Luego debes moverlos a /etc/openvpn en el cliente. Los archivos de configuración: openvpn.confAún en el cliente crea un archivo llamado openvpn.conf en /etc/openvpn y escribe lo siguiente en él:
No olvides reemplazar x.y.z.w por el IP público de tu servidor. Ahora en el servidor crea un archivo openvpn.conf en /etc/openvpn y escribe lo siguiente en él:
En mi primeras pruebas tuve conexiones muy lentas y me ayudó desactivar la compresión en cliente y servidor comentando esta línea: #comp-lzo Y finalmente configura IP forwarding e iptables para NAT en el servidor: echo 1 > /proc/sys/net/ipv4/ip_forward sudo iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE Puedes verificar que la regla fue escrita correctamente con un listado: Si tienes un Firewall deberás desactivarlo para probar y luego crear reglas que permitan que el tráfico de tu VPN pase. Si quieres remover todas las reglas si cometiste un error con: Reiniciar OpenVPN en ambos equipos, cliente y servidor, y deberías estar listo. Si ahora ejecutas ifconfig y route -n deberías ver una nueva interfaz, tun0, en cliente y servidor. Puedes confirmar que hay conexíon haciendo ping entre ambos usando los IP de las interfaces tun0, por ejemplo: ping 10.8.0.1 Ahora tu cliente está conectado al servidor a través de OpenVPN y puedes navegar en forma segura a través del IP del servidor (y usar Hulu y Pandora). Suerte. Recursos adicionales
Trackback URL for this post:http://www.ventanazul.com/trackback/185
|
¿Quieres tener tu propia tienda en Internet, necesitas un nuevo diseño para tu sitio web, promocionar tus productos y servicios en la Red o construir una comunidad virtual? No hay problema, hablemos de ello. www.flickr.com
This is a Flickr badge showing public photos from alexisbellido. Make your own badge here.
|
Perfecto Gracias
Horale esta muy bueno tu tutorial estaba buscando por la red como montarme un servidor VPN y me encontre con tu tutorial resulta que quiero montar una red privada gracias lo probare :)
Excelente Tutorial
Hola de antemano muchas gracias por el tutorial, realmente llevaba tiempo intentando hacer una vpn con openvpn y no habia podido pero ahora ya lo pude hacer.
Sigan publicando tutos como este muy claros a la hora de aplicarlos y solo tuve una pequeña perdida cuando se generan los certificados pero lo unico es ubicarse en la carpeta de easy-rsa.
Gracias....
Vienen más tutoriales en camino
Tan pronto encuentre el tiempo :)
Saludos.
Alexis Bellido
Enviar un comentario nuevo