docs/sp_SP: Add translation for scheduler/sched-design-CFS.rst
Translate Documentation/scheduler/sched-design-CFS.rst into Spanish Signed-off-by: Sergio González Collado <sergio.collado@gmail.com> Reviewed-by: Carlos Bilbao <carlos.bilbao.osdev@gmail.com> Signed-off-by: Jonathan Corbet <corbet@lwn.net> Link: https://lore.kernel.org/r/20240707195047.14359-1-sergio.collado@gmail.com
This commit is contained in:
parent
7f60f33d46
commit
0a0d5f32b0
@ -1,3 +1,5 @@
|
|||||||
|
.. _sched_design_CFS:
|
||||||
|
|
||||||
=============
|
=============
|
||||||
CFS Scheduler
|
CFS Scheduler
|
||||||
=============
|
=============
|
||||||
|
@ -78,3 +78,4 @@ Traducciones al español
|
|||||||
|
|
||||||
process/index
|
process/index
|
||||||
wrappers/memory-barriers
|
wrappers/memory-barriers
|
||||||
|
scheduler/index
|
||||||
|
8
Documentation/translations/sp_SP/scheduler/index.rst
Normal file
8
Documentation/translations/sp_SP/scheduler/index.rst
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
.. include:: ../disclaimer-sp.rst
|
||||||
|
|
||||||
|
.. _sp_scheduler_index:
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
sched-design-CFS
|
277
Documentation/translations/sp_SP/scheduler/sched-design-CFS.rst
Normal file
277
Documentation/translations/sp_SP/scheduler/sched-design-CFS.rst
Normal file
@ -0,0 +1,277 @@
|
|||||||
|
.. include:: ../disclaimer-sp.rst
|
||||||
|
|
||||||
|
:Original: :ref:`Documentation/scheduler/sched-design-CFS.rst <sched_design_CFS>`
|
||||||
|
:Translator: Sergio González Collado <sergio.collado@gmail.com>
|
||||||
|
|
||||||
|
.. _sp_sched_desing_CFS:
|
||||||
|
|
||||||
|
====================
|
||||||
|
Gestor de tareas CFS
|
||||||
|
====================
|
||||||
|
|
||||||
|
1. VISIÓN GENERAL
|
||||||
|
==================
|
||||||
|
|
||||||
|
CFS viene de las siglas en inglés de "Gestor de tareas totalmente justo"
|
||||||
|
("Completely Fair Scheduler"), y es el nuevo gestor de tareas de escritorio
|
||||||
|
implementado por Ingo Molnar e integrado en Linux 2.6.23. Es el sustituto de
|
||||||
|
el previo gestor de tareas SCHED_OTHER.
|
||||||
|
|
||||||
|
Nota: El planificador EEVDF fue incorporado más recientemente al kernel.
|
||||||
|
|
||||||
|
El 80% del diseño de CFS puede ser resumido en una única frase: CFS
|
||||||
|
básicamente modela una "CPU ideal, precisa y multi-tarea" sobre hardware
|
||||||
|
real.
|
||||||
|
|
||||||
|
"una CPU multitarea ideal" es una CPU (inexistente :-)) que tiene un 100%
|
||||||
|
de potencia y que puede ejecutar cualquier tarea exactamente a la misma
|
||||||
|
velocidad, en paralelo, y cada una a 1/n velocidad. Por ejemplo, si hay dos
|
||||||
|
tareas ejecutándose, entonces cada una usa un 50% de la potencia --- es decir,
|
||||||
|
como si se ejecutaran en paralelo.
|
||||||
|
|
||||||
|
En hardware real, se puede ejecutar una única tarea a la vez, así que
|
||||||
|
se ha usado el concepto de "tiempo de ejecución virtual". El tiempo
|
||||||
|
de ejecución virtual de una tarea específica cuando la siguiente porción
|
||||||
|
de ejecución podría empezar en la CPU ideal multi-tarea descrita anteriormente.
|
||||||
|
En la práctica, el tiempo de ejecución virtual de una tarea es el
|
||||||
|
tiempo de ejecución real normalizado con respecto al número total de
|
||||||
|
tareas ejecutándose.
|
||||||
|
|
||||||
|
|
||||||
|
2. UNOS CUANTOS DETALLES DE IMPLEMENTACIÓN
|
||||||
|
===========================================
|
||||||
|
|
||||||
|
En CFS, el tiempo de ejecución virtual se expresa y se monitoriza por
|
||||||
|
cada tarea, en su valor de p->se.vruntime (en unidades de nanosegundos).
|
||||||
|
De este modo, es posible temporizar con precisión y medir el "tiempo
|
||||||
|
de CPU esperado" que una tarea debería tener.
|
||||||
|
|
||||||
|
Un pequeño detalle: en hardware "ideal", en cualquier momento todas las
|
||||||
|
tareas pueden tener el mismo valor de p->se.vruntime --- i.e., tareas
|
||||||
|
se podrían ejecutar simultáneamente y ninguna tarea podría escaparse del
|
||||||
|
"balance" de la partición "ideal" del tiempo compartido de la CPU.
|
||||||
|
|
||||||
|
La lógica de elección del tareas de CFS se basa en el valor de p->se.vruntime
|
||||||
|
y por tanto es muy sencilla: siempre intenta ejecutar la tarea con el valor
|
||||||
|
p->se.vruntime más pequeño (i.e., la tarea que se ha ejecutado menos hasta el
|
||||||
|
momento). CFS siempre intenta dividir el espacio de tiempo entre tareas
|
||||||
|
en ejecución tan próximo a la "ejecución multitarea ideal del hardware" como
|
||||||
|
sea posible.
|
||||||
|
|
||||||
|
El resto del diseño de CFS simplemente se escapa de este simple concepto,
|
||||||
|
con unos cuantos añadidos como los niveles "nice" ("nice" significa "amable"
|
||||||
|
en inglés), multi-tarea y varias variantes del algoritmo para identificar
|
||||||
|
tareas "durmiendo".
|
||||||
|
|
||||||
|
|
||||||
|
3. EL ÁRBOL ROJO-NEGRO
|
||||||
|
=======================
|
||||||
|
|
||||||
|
El diseño de CFS es bastante radical: no utiliza las antiguas estructuras
|
||||||
|
de datos para las colas de ejecución (en inglés "runqueues"), pero usa una
|
||||||
|
estructura de árbol rojo-negro (en inglés "red-black tree") ordenado cronológicamente
|
||||||
|
para construir un línea de ejecución en el futuro, y por eso no tiene ningún
|
||||||
|
artificio de "cambio de tareas" (algo que previamente era usado por el gestor
|
||||||
|
anterior y RSDL/SD).
|
||||||
|
|
||||||
|
CFS también mantiene el valor de rq->cfs.min_vruntime, el cual crece
|
||||||
|
monotónicamente siguiendo el valor más pequeño de vruntime de entre todas
|
||||||
|
las tareas en la cola de ejecución. La cantidad total de trabajo realizado
|
||||||
|
por el sistema es monitorizado usado min_vruntime; este valor es usado
|
||||||
|
para situar las nuevas tareas en la parte izquierda del árbol tanto
|
||||||
|
como sea posible.
|
||||||
|
|
||||||
|
El valor total de tareas ejecutándose en la cola de ejecución es
|
||||||
|
contabilizado mediante el valor rq->cfs.load, el cual es la suma de los
|
||||||
|
de esas tareas que están en la cola de ejecución.
|
||||||
|
|
||||||
|
CFS mantiene un árbol rojo-negro cronológicamente ordenado, donde todas las
|
||||||
|
tareas que pueden ser ejecutadas están ordenadas por su valor de
|
||||||
|
p->se.vruntime. CFS selecciona la tarea más hacia la izquierda de este
|
||||||
|
árbol y la mantiene. Según el sistema continúa, las tareas ejecutadas
|
||||||
|
se ponen en este árbol más y más hacia la derecha --- lentamente pero
|
||||||
|
de forma continuada dando una oportunidad a cada tarea de ser la que
|
||||||
|
está "la más hacia la izquierda" y por tanto obtener la CPU una cantidad
|
||||||
|
determinista de tiempo.
|
||||||
|
|
||||||
|
Resumiendo, CFS funciona así: ejecuta una tarea un tiempo, y cuando la
|
||||||
|
tarea se gestiona (o sucede un tic del gestor de tareas) se considera
|
||||||
|
que el tiempo de uso de la CPU se ha completado, y se añade a
|
||||||
|
p->se.vruntime. Una vez p->se.vruntime ha aumentado lo suficiente como
|
||||||
|
para que otra tarea sea "la tarea más hacia la izquierda" del árbol
|
||||||
|
rojo-negro ordenado cronológicamente esta mantienen (más una cierta pequeña
|
||||||
|
cantidad de distancia relativa a la tarea más hacia la izquierda para
|
||||||
|
que no se sobre-reserven tareas y perjudique a la cache), entonces la
|
||||||
|
nueva tarea "que está a la izquierda del todo", es la que se elige
|
||||||
|
para que se ejecute, y la tarea en ejecución es interrumpida.
|
||||||
|
|
||||||
|
4. ALGUNAS CARACTERÍSTICAS DE CFS
|
||||||
|
==================================
|
||||||
|
|
||||||
|
CFS usa una granularidad de nanosegundos y no depende de ningún
|
||||||
|
jiffie o detalles como HZ. De este modo, el gestor de tareas CFS no tiene
|
||||||
|
noción de "ventanas de tiempo" de la forma en que tenía el gestor de
|
||||||
|
tareas previo, y tampoco tiene heurísticos. Únicamente hay un parámetro
|
||||||
|
central ajustable (se ha de cambiar en CONFIG_SCHED_DEBUG):
|
||||||
|
|
||||||
|
/sys/kernel/debug/sched/base_slice_ns
|
||||||
|
|
||||||
|
El cual puede ser usado para afinar desde el gestor de tareas del "escritorio"
|
||||||
|
(i.e., bajas latencias) hacia cargas de "servidor" (i.e., bueno con
|
||||||
|
procesamientos). Su valor por defecto es adecuado para tareas de escritorio.
|
||||||
|
SCHED_BATCH también es gestionado por el gestor de tareas CFS.
|
||||||
|
|
||||||
|
Debido a su diseño, el gestor de tareas CFS no es proclive a ninguno de los
|
||||||
|
ataques que existen a día de hoy contra los heurísticos del gestor de tareas:
|
||||||
|
fiftyp.c, thud.c, chew.c, ring-test.c, massive_intr.c todos trabajan
|
||||||
|
correctamente y no tienen impacto en la interacción y se comportan de la forma
|
||||||
|
esperada.
|
||||||
|
|
||||||
|
El gestor de tareas CFS tiene una gestión mucho más firme de los niveles
|
||||||
|
"nice" y SCHED_BATCH que los previos gestores de tareas: ambos tipos de
|
||||||
|
tareas están aisladas de forma más eficiente.
|
||||||
|
|
||||||
|
El balanceo de tareas SMP ha sido rehecho/mejorado: el avance por las
|
||||||
|
colas de ejecución de tareas ha desaparecido del código de balanceo de
|
||||||
|
carga, y ahora se usan iteradores en la gestión de módulos. El balanceo
|
||||||
|
del código ha sido simplificado como resultado esto.
|
||||||
|
|
||||||
|
5. Políticas de gestión de tareas
|
||||||
|
==================================
|
||||||
|
|
||||||
|
CFS implementa tres políticas de gestión de tareas:
|
||||||
|
|
||||||
|
- SCHED_NORMAL (tradicionalmente llamada SCHED_OTHER): Gestión de
|
||||||
|
tareas que se usan para tareas normales.
|
||||||
|
|
||||||
|
- SCHED_BATCH: No interrumpe tareas tan a menudo como las tareas
|
||||||
|
normales harían, por eso permite a las tareas ejecutarse durante
|
||||||
|
ventanas de tiempo mayores y hace un uso más efectivo de las
|
||||||
|
caches pero al coste de la interactividad. Esto es adecuado
|
||||||
|
para trabajos de procesado de datos.
|
||||||
|
|
||||||
|
- SCHED_IDLE: Esta política es más débil incluso que nice 19, pero
|
||||||
|
no es un gestor "idle" para evitar caer en el problema de la
|
||||||
|
inversión de prioridades que causaría un bloqueo de la máquina
|
||||||
|
(deadlock).
|
||||||
|
|
||||||
|
SCHED_FIFO/_RR se implementan en sched/rt.c y son específicos de
|
||||||
|
POSIX.
|
||||||
|
|
||||||
|
El comando chrt de util-linux-ng 2.13.1.1. puede asignar cualquiera de
|
||||||
|
estas políticas excepto SCHED_IDLE.
|
||||||
|
|
||||||
|
|
||||||
|
6. CLASES DE GESTIÓN
|
||||||
|
=====================
|
||||||
|
|
||||||
|
El nuevo gestor de tareas CFS ha sido diseñado de tal modo para incluir
|
||||||
|
"clases de gestión", una jerarquía ampliable de módulos que pueden tener
|
||||||
|
distintas políticas de gestión de tareas. Estos módulos encapsulan los
|
||||||
|
detalles de las politicas de gestión y son manejadas por el núcleo del
|
||||||
|
gestor de tareas sin que este tenga que presuponer mucho sobre estas clases.
|
||||||
|
|
||||||
|
sched/fair.c implementa el gestor de tareas CFS descrito antes.
|
||||||
|
|
||||||
|
sched/rt.c implementa la semántica de SCHED_FIFO y SCHED_RR, de una forma
|
||||||
|
más sencilla que el gestor de tareas anterior. Usa 100 colas de ejecución
|
||||||
|
(por todos los 100 niveles de prioridad RT, en vez de las 140 que necesitaba
|
||||||
|
el gestor de tareas anterior) y no necesita las listas de expiración.
|
||||||
|
|
||||||
|
Las clases de gestión de tareas son implementadas por medio de la estructura
|
||||||
|
sched_class, la cual tiene llamadas a las funciones que deben de llamarse
|
||||||
|
cuando quiera que ocurra un evento interesante.
|
||||||
|
|
||||||
|
Esta es la lista parcial de llamadas:
|
||||||
|
|
||||||
|
- enqueue_task(...)
|
||||||
|
|
||||||
|
Llamada cuando una tarea entra en el estado de lista para ejecución.
|
||||||
|
Pone la entidad a ser gestionada (la tarea) en el árbol rojo-negro
|
||||||
|
e incrementa la variable nr_running.
|
||||||
|
|
||||||
|
- dequeue_task(...)
|
||||||
|
|
||||||
|
Cuando una tarea deja de ser ejecutable, esta función se llama para
|
||||||
|
mantener a la entidad gestionada fuera del árbol rojo-negor. Esto
|
||||||
|
decrementa la variable nr_running.
|
||||||
|
|
||||||
|
- yield_task(...)
|
||||||
|
|
||||||
|
Esta función es básicamente desencolar, seguido por encolar, a menos que
|
||||||
|
sysctl compat_yield esté activado; en ese caso, sitúa la entidad a gestionar
|
||||||
|
en la parte más hacia la derecha del árbol rojo-negro.
|
||||||
|
|
||||||
|
- check_preempt_curr(...)
|
||||||
|
|
||||||
|
Esta función comprueba si una tarea que ha entrado en el estado de
|
||||||
|
poder ser ejecutada, podría reemplazar a la tarea que actualmente
|
||||||
|
se esté ejecutando.
|
||||||
|
|
||||||
|
- pick_next_task(...)
|
||||||
|
|
||||||
|
Esta función elige la tarea más apropiada para ser ejecutada a continuación.
|
||||||
|
|
||||||
|
- set_curr_task(...)
|
||||||
|
|
||||||
|
Esta función se llama cuando una tarea cambia su clase de gestión o
|
||||||
|
cambia su grupo de tareas.
|
||||||
|
|
||||||
|
- task_tick(...)
|
||||||
|
|
||||||
|
Esta función es llamada la mayoría de las veces desde la función de tiempo
|
||||||
|
tick; esto puede llevar a un cambio de procesos. Esto dirige el reemplazo
|
||||||
|
de las tareas.
|
||||||
|
|
||||||
|
|
||||||
|
7. EXTENSIONES DE GRUPOS PARA CFS
|
||||||
|
==================================
|
||||||
|
|
||||||
|
Normalmente, el gestor de tareas gestiona tareas individuales e intenta
|
||||||
|
proporcionar una cantidad justa de CPU a cada tarea. Algunas veces, puede
|
||||||
|
ser deseable agrupar las tareas y proporcionarles una cantidad justa
|
||||||
|
de tiempo de CPU a cada una de las tareas de ese grupo. Por ejemplo,
|
||||||
|
podría ser deseable que primero se proporcione una cantidad justa de
|
||||||
|
tiempo de CPU a cada usuario del sistema y después a cada tarea
|
||||||
|
que pertenezca a un usuario.
|
||||||
|
|
||||||
|
CONFIG_CGROUP_SCHED destaca en conseguir exactamente eso. Permite a las
|
||||||
|
tareas ser agrupadas y divide el tiempo de CPU de forma just entre esos
|
||||||
|
grupos.
|
||||||
|
|
||||||
|
CONFIG_RT_GROUP_SCHED permite agrupar tareas de tiempo real (i.e.,
|
||||||
|
SCHED_FIFO y SCHED_RR).
|
||||||
|
|
||||||
|
CONFIG_FAIR_GROUP_SCHED permite agrupar tareas de CFS (i.e., SCHED_NORMAL y
|
||||||
|
SCHED_BATCH).
|
||||||
|
|
||||||
|
Estas opciones necesitan CONFIG_CGROUPS para ser definidas, y permitir
|
||||||
|
al administrador crear grupos arbitrarios de tareas, usando el pseudo
|
||||||
|
sistema de archivos "cgroup". Vease la documentación para más información
|
||||||
|
sobre este sistema de archivos: Documentation/admin-guide/cgroup-v1/cgroups.rst
|
||||||
|
|
||||||
|
Cuando CONFIG_FAIR_GROUP_SCHED es definido, un archivo
|
||||||
|
"cpu.shares" es creado por cada grupo creado usado en el pseudo
|
||||||
|
sistema de archivos. Véanse por ejemplo los pasos a continuación
|
||||||
|
para crear grupos de tareas y modificar cuanto comparten de la CPU
|
||||||
|
usando el pseudo sistema de archivos "cgroup" ::
|
||||||
|
|
||||||
|
# mount -t tmpfs cgroup_root /sys/fs/cgroup
|
||||||
|
# mkdir /sys/fs/cgroup/cpu
|
||||||
|
# mount -t cgroup -ocpu none /sys/fs/cgroup/cpu
|
||||||
|
# cd /sys/fs/cgroup/cpu
|
||||||
|
|
||||||
|
# mkdir multimedia # crear un grupo de tareas "multimedia"
|
||||||
|
# mkdir browser # crear un grupo de tareas "browser"
|
||||||
|
|
||||||
|
# #Configurar el grupo multimedia para tener el doble de tiempo de CPU
|
||||||
|
# #que el grupo browser
|
||||||
|
|
||||||
|
# echo 2048 > multimedia/cpu.shares
|
||||||
|
# echo 1024 > browser/cpu.shares
|
||||||
|
|
||||||
|
# firefox & # Lanzar firefox y moverlo al grupo "browser"
|
||||||
|
# echo <firefox_pid> > browser/tasks
|
||||||
|
|
||||||
|
# #Lanzar gmplayer (o su programa favorito de reproducción de películas)
|
||||||
|
# echo <movie_player_pid> > multimedia/tasks
|
Loading…
Reference in New Issue
Block a user