Tabla de Contenidos

13 - Acceso remoto

El acceso remoto es un concepto fundamental en los servicios de red que permite a los usuarios interactuar con dispositivos, sistemas o redes desde ubicaciones físicas distintas. Esta tecnología es esencial en entornos modernos, donde la movilidad y la descentralización de los equipos de trabajo son cada vez más comunes.

El acceso remoto facilita tareas como la administración de servidores, la transferencia de archivos, el soporte técnico y el teletrabajo, garantizando que los recursos de una red sean accesibles desde cualquier parte del mundo. Sin embargo, también plantea desafíos importantes en términos de seguridad, rendimiento y confiabilidad.

En este apartado, exploraremos los conceptos clave, las tecnologías utilizadas, los métodos de implementación y las mejores prácticas para garantizar un acceso remoto seguro y eficiente.

Tecnologías

El acceso remoto se basa en diversas tecnologías y protocolos que permiten la conexión a dispositivos y redes de manera eficiente y segura.

SSH (Secure Shell)

SSH es un protocolo criptográfico que asegura el acceso remoto a dispositivos, especialmente servidores. Es ampliamente utilizado en sistemas Unix/Linux debido a su robustez y facilidad de uso.

ssh usuario@servidor.com

RDP (Remote Desktop Protocol)

RDP, desarrollado por Microsoft, es una herramienta para acceder de forma remota a escritorios en sistemas Windows. Este protocolo es ideal para administrar máquinas de forma gráfica.

VPN (Virtual Private Network)

Las VPN permiten una conexión segura entre un dispositivo remoto y una red interna mediante el cifrado de datos. Son especialmente útiles en entornos corporativos.

Telnet

Telnet es uno de los protocolos más antiguos para el acceso remoto. Sin embargo, su falta de cifrado lo hace inseguro para el uso moderno.

SFTP

Variante segura de FTP que utiliza SSH para cifrar las transferencias de archivos.

sftp usuario@servidor.com

SSH

SSH es una de las tecnologías más utilizadas para el acceso remoto seguro, especialmente en entornos Linux/Unix. Proporciona un canal cifrado que protege la integridad y confidencialidad de las comunicaciones entre cliente y servidor.

Características Principales

Estructura Básica de una Conexión SSH

La conexión SSH se realiza mediante un cliente y un servidor. El cliente inicia la conexión y proporciona credenciales para autenticarse en el servidor.

ssh usuario@servidor.com

Generación de Claves SSH

El sistema de claves públicas/privadas es un mecanismo de autenticación asimétrica que proporciona una forma más segura de verificar la identidad entre cliente y servidor. Este método elimina la necesidad de enviar contraseñas a través de la red, reduciendo el riesgo de ataques como el phishing o la captura de credenciales.

Ambas claves están matemáticamente relacionadas, de modo que lo que se cifra con una puede ser descifrado únicamente con la otra.

Proceso de Autenticación

Ventajas del Sistema de Claves Públicas/Privadas

Archivos Clave en SSH

Transferencia de Archivos con SSH

SSH facilita la transferencia de archivos de manera segura usando herramientas como scp y sftp.

scp archivo.txt usuario@servidor.com:/ruta/destino

scp usuario@servidor.com:/ruta/origen/archivo.txt ./  

Túneles SSH

Un túnel SSH es una técnica que permite redirigir el tráfico de red a través de una conexión SSH segura. Esto es útil para proteger la transmisión de datos entre un cliente y un servidor o para acceder a recursos de una red remota como si estuvieran locales.

Un túnel SSH se establece redirigiendo los puertos entre el cliente y el servidor.

El túnel permite encapsular datos que viajan a través de la conexión SSH, asegurándolos con cifrado.

Tipos de Túneles SSH

Reenvío de Puertos Local (Local Port Forwarding)

Supongamos que tienes un servidor remoto (servidor.com) que puede acceder a una base de datos MySQL en localhost:3306. Desde tu máquina local, puedes redirigir este puerto así:

ssh -L 3307:localhost:3306 usuario@servidor.com

Ahora puedes conectarte a localhost:3307 en tu máquina local como si estuvieras accediendo directamente a la base de datos remota.

Reenvío de Puertos Remoto (Remote Port Forwarding)

Permite redirigir el tráfico desde un puerto en el servidor remoto a un puerto en la máquina cliente. Útil para exponer un servicio local a través de un servidor remoto.

Supongamos que tienes un servidor web local en el puerto 8080 de tu máquina y quieres que sea accesible desde el servidor remoto (servidor.com) en el puerto 9090:

ssh -R 9090:localhost:8080 usuario@servidor.com

Ahora, cualquier conexión al servidor remoto en el puerto 9090 se redirigirá a tu servidor web local en el puerto 8080.

Reenvío Dinámico de Puertos (Dynamic Port Forwarding)

Funciona como un proxy SOCKS, permitiendo redirigir tráfico de múltiples servicios o puertos a través del túnel SSH. Útil para navegar de forma segura o acceder a múltiples servicios en una red remota.

Para crear un proxy SOCKS en el puerto 1080 de tu máquina local:

ssh -D 1080 usuario@servidor.com

Luego, puedes configurar aplicaciones o navegadores para usar localhost:1080 como un proxy SOCKS.

Ventajas de los Túneles SSH

Casos de Uso de los Túneles SSH