Modelo M\M\1\k
From JavierValcarce.Es
Este modelo representa a un servidor (web, ftp, etc) que no hace fork() sino que pone en una cola de espera de tamaño finito las conexiones TCP entrantes y las atiende una a una por orden de llegada (FIFO).
Recuerda que en la API de sockets Berkely, la llamada a
int listen(int ds, int nb)
permite especificar el tamaño máximo de la cola (parámetro nb) de espera para las conexiones TCP entrantes (llamadas "tareas" a partir de ahora).
Pregunta: ¿Cual es la probabilidad B de que una conexión TCP entrante sea rechazada porque la cola esté llena?
| λ | Tráfico ofrecido (tareas/s) |
| λc | Tráfico cursado (tareas/s) |
| μ | Velocidad de servicio (tareas/s) |
| B | Probabilidad de bloqueo |
| k | Capacidad del sistema (tareas) |
Si el tráfico proviene de un número muy elevado de usuarios independientes entonces se puede caracterizar estadísticamente como de Poisson. La duración de las conexiones, por otra parte, se ha demostrado empíricamente que se puede caracterizase por ser de Pareto(m, α) con α < 2. Así pues, podemos usar un modelo M/M/1/k[1] para tener una respuesta aproximada a la pregunta anterior.
La probabilidad de bloqueo (B) de tareas que he obtenido es
siendo r = λ / μ la intensidad de tráfico ofrecido al sistema. Puedo por fin confirmar que el resultado al que he llegado es correcto. Después de buscar durante algún tiempo finalmente encontré un libro (ver Referencias) en el que aparece este modelo y, aunque no aparece la demostración, el resultado final es el mismo. Ok.
Demostración
La distribución de probabilidad de ocupación del sistema se obtiene considerando al proceso de ocupación del sistema N(t) como un proceso de nacimiento y muerte[1] de una dimensión. Las tasas de nacimiento y muerte en cada estado son
y
con
Utilizando que la suma de una distribución de probabilidad vale 1, despejamos p0 y usamos la suma de una progresión geométrica finita
La distribución de probabilidad de ocupación del sistema es
Por la propiedad PASTA (Poisson Arrivals See Time Averages) del proceso de llegada de Poisson, la probabilidad de bloqueo de una tarea (B) es igual a la probabilidad de bloqueo temporal (BT)
con
La expresión es indeterminada en r = 1, es decir, que para este valor el sistema no se encuentra en equilibrio estadístico (?). Esto es muy interesante y no se muy bien cómo interpretarlo. En el límite, cuando
, usando la regla de L'Hôpital para deshacer la indeterminación, tenemos
Suponiendo que B es una función continua, tenemos finalmente
La expresión parece correcta (B tiende a 0 cuando disminuye el tráfico o cuando aumenta el tamaño de la cola) pero la indeterminación en r = 1 me mosquea.
Gráfica
Fichero: mm1k.m
Referencias
- "Teoría de colas y simulación de eventos discretos", José Juan Pazos Arias, Andrés Suárez González y Rebeca P. Díaz Redondo, Pearson, ISBN 84-205-3675-X
- TELETRAFFIC ENGINEERING HANDBOOK
