jueves, 15 de marzo de 2012

Administración de un LVS con ipvsadm


ipvsadm es una herramienta de línea de comando utilizada para la instalación, administración del LVS. La versión más reciente de ipvsadm fue liberada en febrero de 2011.

El comando tiene dos formas básicas de ejecución:

ipvsadm COMMAND [protocol] service-address
        [scheduling-method] [persistence options]

ipvsadm command [protocol] service-address
        server-address [packet-forwarding-method]
        [weight options]

La primera forma es para ser ejecutada en el nodo director y la segunda en los servidores reales. Una descripción detallada de los comandos y parámetros que acepta ipvsadm puede ser consultada aquí.


Comandos y parámetros

Entre las comandos más importantes, tenemos:
  • -A: permite agregar un servicio virtual
  • -C: limpia la tabla del lvs. Es importante un ipvsadm -C antes de iniciar una nueva configuración.
  • -a: permite agregar un servidor real a un servicio virtual.
  • -d: permite eliminar un servidor real de un servicio virtual.
En cuanto a los parámetros aceptados, están:
  • -t service-address: se utiliza para indicar que se agregará un servicio TCP. service-address debe ser especificada de la forma host[:port], siendo host una dirección IP o un hostname y port el número de puerto o el nombre del servicio (por ejemplo http).
  • -u service-address: igual que el anterior, pero indica que el servicio será UDP.
  • -s scheduling-method: se utiliza para especificar el algoritmo de planificación a utilizar. Los valores válidos para scheduling-method son:
    • rr (Round-Robin)
    • wrr (Weighted Round-Robin)
    • lc (Least-Connection)
    • wlc (Weighted Least-Connection)
    • lblc (Locality-Based Least-Connection)
    • lblcr (Locality-Based Least-Connection with Replication)
    • dh (Destination Hashing)
    • sh (Source Hashing)
    • sed (Shortest Expected Delay)
    • nq (Never Queue)
  • -r server-address: se utiliza para especificar la dirección ip de un servidor real, y opcionalmente puede agregarse un número de puerto.
  • -w weight: Se utiliza para especificar el peso de un servidor real. El peso es un valor numérico que indica la capacidad de procesamiento del servidor, relativa al conjunto de servidores. El rango de valores válidos de weight es [0, 65536]. El valor por omisión es 1. Un servidor con peso 5 indica que tiene mayor capacidad de procesamiento que un servidor con peso 2, y por tanto recibirá mayor número de peticiones.

Ejemplo práctico

Supongamos una red formada por un nodo director y 2 servidores reales con las siguientes direcciones IP:

La dirección IP que utilizaremos para el servicio virtual será: 192.168.122.110. Podemos configurar el LVS en el nodo director de la siguiente manera:

#clear ipvsadm table
ipvsadm -C

#especify the virtual service with Round-Robin algorithm
ipvsadm -A -t 192.168.122.110:http -s rr

#forward telnet to realserver 1 with weight 1
ipvsadm -a -t 192.168.122.110:http -r 192.168.122.225 -w 1

#forward telnet to realserver 2 with weight 3
ipvsadm -a -t 192.168.122.110:http -r 192.168.122.38 -w 3

1 comentario:

maykel dijo...

Muy buen tutorial, me sirvió, gracias.