Pound - Servidor Proxy Reverso

Pound - Servidor Proxy Reverso es un proxy reverso de configuración simple y versátil. Es Software libre, pudiéndose descargar libremente desde internet, y ser utilizado y modificado de acuerdo a las necesidades del usuario.

Pound
Información general
Tipo de programa Servidor Web
Autor Robert Segall, Apsis GmbH
Licencia GNU General Public License
Estado actual Estable
Idiomas Inglés
Información técnica
Programado en C, HTTP, HTTPS
Versiones
Última versión estable 2.8 (info) ( 11 de mayo de 2018 (5 años, 11 meses y 14 días))
Última versión en pruebas 2.8a (info) ( 23 de octubre de 2016 (7 años, 6 meses y 2 días))
Enlaces

Historia editar

De acuerdo a la definición encontrada en el sitio de “Apsis IT Security” (https://web.archive.org/web/20031002052833/http://www.apsis.ch/pound/index.html), o bien a la definición de la página de manual (LINUX: man pound), Pound es un reverse-proxy capaz de realizar balance de carga. Pound acepta peticiones de clientes HTTP/HTTPS y las distribuye hacia uno o varios servidores web. En el caso de las peticiones HTTPS, las mismas son descifrados por Pound, y pasadas a los servidores web como http plano.

Pound es capaz de detectar cuando un servidor web no responde, evitando enviar peticiones a éstos hasta que restablezcan su función correcta.

En caso de declararse más de un servidor web en la configuración, Pound escoge aleatoriamente, basado en las prioridades definidas. Pound realiza también la tarea de mantener las sesiones establecidas entre los clientes y los servidores web.

Instalación editar

Al instalar el Pound (en Debian y derivados: apt-get install pound), los archivos de configuración se ubicarán en la carpeta /etc/pound/

Los archivos relevantes para determinar el funcionamiento del reverse-proxy son:

/etc/pound/pound.conf /etc/pound/cert.pem

En caso de utilizar el pound para gestionar peticiones HTTPS, el último archivo mencionado guarda el certificado de clave pública para HTTPS. La ubicación de este archivo, junto con el resto de la configuración del reverse-proxy, se sitúa dentro del primer archivo (/etc/pound/pound.conf)


Para definir correctamente el comportamiento de Pound, el archivo de configuración deberá considerar al menos los siguientes 3 elementos:

  • HTTPListeners
  • Services
  • BackEnds

Listeners editar

Los Listeners definen la forma en que Pound recibe las peticiones de los clientes. Los dos tipos posibles de Listeners son HTTP y HTTPS.

Servicios editar

Los servicios definen el modo en que se responderá a las peticiones. Los servicios pueden ser definidos dentro de un listener (actuando únicamente para las peticiones que cumplan las condiciones definidas en ese listener), o globalmente, actuando para todas las peticiones. Los servicios imponen también condiciones, indicando a qué tipo de petición se refieren. En particular, puede definirse un servicio para que filtre o redirija las peticiones que involucren una determinada URL, o en cuyo encabezado se identifique un patrón determinado. En el ejemplo al final de este texto, se define un servicio para identificar la petición de archivos de imagen del tipo png, a fin de descargar todas estas imágenes de un mismo back-end (servido web).

Back-Ends editar

Los Back-Ends identifican a los servidores web reales que contienen la información pedida por el cliente. Existen 3 tipos de BackEnd: Regular: recibe las peticiones y devuelve el contenido buscado respuestas. Redirect: en este caso el Pound responde con una orden de redireccionamiento. Emergency: Responde únicamente en caso de que todos los demás back-ends estén fuera de servicio.

En cada servicio pueden definirse varios Back-Ends. En ese caso Pound los elegirá aleatoriamente basándose en las prioridades asignadas a cada uno.

Configuración editar

Ejemplo de aplicación:

Configuración del archivo /etc/pound/pound.conf

User	“www-data”
Group	“www-data”

LogLevel	1

Alive	5

ListenHTTP
	Address 192.168.135.129
	Port	80
	
	Service
		HeadRequire	“.png”

		BackEnd
			Address 127.0.0.1	#Servidor que almacena las imágenes
			Port	8080
		End
	End
	
	Service
		BackEnd
			Address	127.0.0.1
			Port 	8080
			Priority	1
		End

		BackEnd
			Address	192.168.135.1
			Port	8080
		        Priority	2
	        End	
	End
End

ListenHTTP
	Address	127.0.0.1
	Port	80
	
	Service
		BackEnd
			Address 127.0.0.1
                        Port	8080
		End
	End
End

La configuración presentada corresponde a una topología de red de 2 máquinas. En esta topología, ambas máquinas corren un servidor web apache, respondiendo solicitudes http a través del puerto 8080. Una de ellas responde únicamente a su dirección de loopback, y corre a su vez el pound (reverse-proxy), respondiendo este último a solicitudes http externas a través del puerto 80.

Ventajas editar

Esta configuración tiene ventajas de seguridad, ya que si bloqueamos las solicitudes entrantes a través del puerto 8080, entonces no habrá forma de llegar a los servidores apache, excepto a través del reverse-proxy que redirige las solicitudes entrantes a los puertos y direcciones IP de los back-ends ubicados en el cluster de computadores.

Enlaces externos editar