Pound - Servidor Proxy Reverso

Pound - Servidor Proxy Reverso

Pound - Servidor Proxy Reverso

pound
Archivo:Http://www.ostyn.com/standardswork/xdomain/Simplest reverse proxy.jpg
Reverse Proxy.
[[1]]
Información general
Diseñado por Robert Segall
Género Servidor Web
Escrito en HTTP, HTTPS
S.O. Multiplataforma
Licencia GNU General Public License
Idiomas Inglés
En español No

Pound - Servidor Proxy Reverso es un reverse proxy 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.

Contenido

Historia

De acuerdo a la definición encontrada en el sitio de “Apsis IT Security” (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 reestablezcan 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 web severs.

Instalación

Al instalar el Pound (en linux: 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

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

Services

Los Services 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 services imponen también condiciones, indicando a qué tipo de petición se refieren. En particular, puede definirse un Service para que filtre o redireccione 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 (web server).

Back-Ends

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 service pueden definirse varios Back-Ends. En ese caso Pound los eligirá aleatoriamente basándose en las prioridades asignadas a cada uno.

Configuración

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

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 redirecciona las solicitudes entrantes a los puertos y direcciones IP de los back-ends ubicados en el cluster de computadores.

Enlaces externos

http://www.apsis.ch/pound/index.html


Wikimedia foundation. 2010.

Игры ⚽ Поможем сделать НИР

Compartir el artículo y extractos

Link directo
Do a right-click on the link above
and select “Copy Link”