Varnish Cache es un acelerador de aplicaciones web, también conocido como caché de proxy HTTP inversa. Se instala delante de cualquier servidor HTTP y se configura para almacenar en el caché del servidor una copia del recurso solicitado. Está ideado para aumentar el rendimiento de aplicaciones web con contenidos pesados y APIs altamente consumidas.

Varnish
Tipo web accelerator, software libre y de código abierto y proxy
Género Acelerador HTTP, Balanceador de Carga
Fundación 2005
Sitio web www.varnish-cache.org

Es una alternativa a otras opciones existentes que plantean caché de cliente o servidores de origen. Además Varnish Cache está orientado exclusivamente a HTTP a diferencia de otros que ofrecen soporte FTP, SMTP u otros protocolos de red.

Actualmente es utilizado por una gran cantidad de sitios web de alta demanda y tráfico como The New York Times, The Guardian, The Hindu, Corriere della Sera, y sitios de redes sociales y contenidos como Wikipedia, Facebook, Twitter, Vimeo, Tumblr, entre otros. De los top 10K sitios en la web, alrededor de una décima parte usan Varnish Cache.

Historia editar

El proyecto fue iniciado como una «rama» del tabloide Noruego Verdens Gang. El arquitecto y desarrollador principal es el consultor independiente danés Poul-Henning Kamp, que también es un conocido desarrollador del núcleo de FreeBSD. El proyecto además contó con la gerencia, infraestructura y desarrollos adicionales aportados por la empresa noruega especializada en código libre y Linux, Linpro. El soporte, gerencia y desarrollo pasó a partir del 2010 a una empresa independiente, Varnish Software.

El proyecto se inició en 2005. Varnish Cache versión 1.0 fue lanzado en septiembre de 2006.[1][2]​ Varnish 2.0 en 2008,[3]​ Varnish 3.0 en 2011,[4]​ y Varnish 4.0 en 2014.[5]

Arquitectura editar

Varnish Cache guarda datos en una memoria virtual del servidor y delega la tarea de decidir qué es lo que se guarda en memoria o se pagina en disco al sistema operativo. Esto ayuda a evitar los problemas que ocurren cuando el sistema operativo comienza a cachear datos mientras estos son movidos a un disco por la aplicación.

Además Varnish Cache hace fuerte uso de múltiples hilos, creando un hilo «obrero» separado por cada cliente. Cuando el número máximo de conexiones es alcanzado, las nuevas conexiones son colocadas en un fila de sobre demanda, hasta que también se alcance el límite máximo de esta fila, cuando las conexiones comienza a ser rechazadas.

Una de las características clave, además de su rendimiento, es la flexibilidad de su configuración del lenguaje VCL (Varnish Configuration Language). VCL es un lenguaje específico de dominio DSL utilizado para implementar ganchos o hooks que son llamados en momentos críticos del manejo de cada solicitud. Cuando un script VCL es cargado, traducido al lenguaje C, compilado a un objeto compartido por el compilador de sistema y cargado directamente en el acelerador, permitiendo reconfiguraciones sin necesidad de reinicios.

VCL permite determinar las políticas a tomar sobre las peticiones de entrada. En esta política se puede decidir qué contenido desea servir, desde donde se desea obtener el contenido y la forma en que la solicitud o la respuesta debe ser alterada. Esto hace a Varnish Cache mucho más configurable y flexible que otros aceleradores HTTP.

Hay una cantidad de parámetros de ejecución para controlar el máximo y mínimo de hilos, timeouts, etc. Existe una interfaz de línea de comando que permite modificar estos parámetros, compilar nuevos scripts VCL, cargarlos y activarlos, sin necesidad de reinicio.

Para reducir la cantidad de llamadas de sistema, la información de logs es almacenada en la memoria compartida, mientras que las tareas de monitoreo, filtrado, formateo y escritura de los logs a disco es delegada una aplicación diferente.

Varnish Modules ofrece soporte de plugins también llamados VMODs[6]

Balanceo de Carga editar

Varnish Cache soporta balanceo de carga usando competencia de parejas (Round robin) o un director aleatorio con pesos asignados por el back-end. También es posible el monitoreo de la salud de los back-ends.[7]

Licencia editar

Varnish Cache es software libre licenciado bajo una licencia BSD. Es posible ofrecer apoyo comercial al proyecto, entre otras fuentes de colaboración.

Referencias editar