La función de ajuste adecuado usa las sugerencias de recursos de Apache Beam para personalizar los recursos de trabajador de una canalización. La capacidad de segmentar varios recursos diferentes para pasos de canalización específicos proporciona flexibilidad y capacidad adicionales de la canalización, y posibles ahorros de costos. Puedes aplicar recursos más costosos a los pasos de canalización que los requieran y recursos menos costosos a otros pasos de canalización. Usa el ajuste adecuado para especificar requisitos de recursos para una canalización completa o para pasos de canalización específicos.
Asistencia y limitaciones
- Las sugerencias de recursos son compatibles con los SDK de Java y Python de Apache Beam, versiones 2.31.0 y posteriores.
- El ajuste adecuado es compatible con las canalizaciones por lotes.
El ajuste adecuado es compatible con las canalizaciones de transmisión con el ajuste de escala automático horizontal habilitado.
- Puedes habilitarlo configurando la opción de canalización
--experiments=enable_streaming_rightfitting.
- Puedes habilitarlo configurando la opción de canalización
El ajuste adecuado admite Dataflow Prime.
El ajuste adecuado no es compatible con FlexRS.
Cuando uses el ajuste adecuado, no uses la opción de servicio
worker_accelerator.
Habilita el ajuste adecuado
Para activar el ajuste adecuado, usa una o más de las sugerencias de recursos disponibles en tu canalización. Cuando usas una sugerencia de recursos en tu canalización, el ajuste adecuado se habilita de forma automática. Para obtener más información, consulta la sección Usa sugerencias de recursos de este documento.
Sugerencias de recursos disponibles
Las siguientes sugerencias de recursos están disponibles.
| Sugerencia de recursos | Descripción |
|---|---|
min_ram |
La cantidad mínima de RAM en gigabytes para asignar a los trabajadores. Dataflow usa este valor como un límite inferior cuando se asigna memoria a trabajadores nuevos (escalamiento horizontal) o a trabajadores existentes (escalamiento vertical). Por ejemplo: min_ram=NUMBERGB
|
accelerator |
Una asignación de GPU proporcionada por el usuario que te permite controlar el uso y el costo de las GPU en tu canalización y sus pasos. Especifica el tipo y la cantidad de GPU que se adjuntarán a los trabajadores de Dataflow como parámetros para la marca. Por ejemplo: accelerator="type:GPU_TYPE;count:GPU_COUNT;machine_type:MACHINE_TYPE;CONFIGURATION_OPTIONS"
Para obtener más información sobre el uso de GPU, consulta GPU con Dataflow. |
Anidación de sugerencias de recursos
Las sugerencias de recursos se aplican a la jerarquía de transformación de canalizaciones de la siguiente manera:
min_ram: El valor en una transformación se evalúa como el valor de sugerenciamin_rammás grande entre los valores establecidos en la transformación y en todos sus elementos superiores en la jerarquía de la transformación.- Ejemplo: Si se configura una sugerencia de transformación interna
min_rama 16 GB, y la sugerencia de transformación externa en los conjuntos de jerarquíamin_rama 32 GB, se usa una sugerencia de 32 GB para todos los pasos de toda la transformación. - Ejemplo: Si se configura una sugerencia de transformación interna
min_rama 16 GB, y la sugerencia de transformación externa en los conjuntos de jerarquíamin_rama 8 GB, se usa una sugerencia de 8 GB para todos los pasos de la transformación externa que no están en la transformación interna y se usa una sugerencia de 16 GB para todos los pasos de la transformación interna.
- Ejemplo: Si se configura una sugerencia de transformación interna
accelerator: El valor más interno en la jerarquía de la transformación tiene prioridad.- Ejemplo: Si una sugerencia de transformación interna
acceleratores distinta de una sugerenciaacceleratorde transformación externa en una jerarquía, la sugerenciaacceleratorde la transformación interna se usará para la transformación interna.
- Ejemplo: Si una sugerencia de transformación interna
Las sugerencias configuradas para toda la canalización se tratan como si estuvieran configuradas en una transformación externa.
Usa sugerencias de recursos
Puedes establecer sugerencias de recursos en toda la canalización o en los pasos de canalización.
Sugerencias de recursos en la canalización
Puedes establecer sugerencias de recursos en toda la canalización cuando la ejecutas desde la línea de comandos.
Para configurar tu entorno de Python, consulta el tutorial de Python.
Ejemplo:
python my_pipeline.py \
--runner=DataflowRunner \
--resource_hints=min_ram=numberGB \
--resource_hints=accelerator="type:type;count:number;install-nvidia-driver" \
...
Sugerencias de recursos en pasos de canalización
Puedes establecer sugerencias de recursos en pasos de canalización (transformaciones) de manera programática.
Java
Si deseas instalar el SDK de Apache Beam para Java, consulta Instala el SDK de Apache Beam.
Puedes establecer sugerencias de recursos de manera programática en transformaciones de canalización mediante la clase ResourceHints.
En el siguiente ejemplo, se muestra cómo establecer sugerencias de recursos de manera programática en transformaciones de canalización.
pcoll.apply(MyCompositeTransform.of(...)
.setResourceHints(
ResourceHints.create()
.withMinRam("15GB")
.withAccelerator(
"type:nvidia-l4;count:1;install-nvidia-driver")))
pcoll.apply(ParDo.of(new BigMemFn())
.setResourceHints(
ResourceHints.create().withMinRam("30GB")))
Para establecer sugerencias de recursos de manera programática en toda la canalización, usa la interfaz ResourceHintsOptions.
Python
Si deseas instalar el SDK de Apache Beam para Python, consulta Instala el SDK de Apache Beam.
Puedes establecer sugerencias de recursos de manera programática en transformaciones de canalización mediante la clase PTransforms.with_resource_hints.
Para obtener más información, consulta la clase ResourceHint.
En el siguiente ejemplo, se muestra cómo establecer sugerencias de recursos de manera programática en transformaciones de canalización.
pcoll | MyPTransform().with_resource_hints(
min_ram="4GB",
accelerator="type:nvidia-tesla-l4;count:1;install-nvidia-driver")
pcoll | beam.ParDo(BigMemFn()).with_resource_hints(
min_ram="30GB")
Para establecer sugerencias de recursos en toda la canalización, usa la opción de canalización --resource_hints cuando ejecutes tu canalización. Para ver un ejemplo, consulta Sugerencias de recursos de canalización.
Go
Las sugerencias de recursos no son compatibles con Go.
Compatibilidad con varios aceleradores
Dentro de una canalización, las diferentes transformaciones pueden tener diferentes configuraciones de acelerador. Esto incluye configuraciones que requieren diferentes tipos de máquinas. Estas configuraciones del acelerador a nivel de la transformación tienen prioridad sobre la configuración a nivel de la canalización, si se proporcionó una.
Ajuste adecuado y fusión
En algunos casos, como parte del proceso de optimización de la fusión, se pueden ejecutar transformaciones configuradas con diferentes sugerencias de recursos en trabajadores que están en el mismo grupo. Cuando las transformaciones se fusionan, Dataflow las ejecuta en un entorno que satisface la unión de las sugerencias de recursos establecida en las transformaciones. En algunos casos, esto incluye toda la canalización.
Cuando no se pueden combinar las sugerencias de recursos, no se produce la fusión. Por ejemplo, las sugerencias de recursos para diferentes GPU no se pueden combinar, por lo que no se combinan esas transformaciones.
Para evitar también la fusión, agrega una operación a la canalización que obligue a Dataflow a materializar una PCollection intermedia. Esto es especialmente útil cuando se intenta aislar recursos costosos, como las GPUs o las máquinas con mucha memoria, de los pasos lentos o que requieren mucha capacidad de procesamiento y que no necesitan esos recursos especiales. En esos casos, puede ser útil forzar una interrupción de la fusión entre los pasos lentos vinculados a la CPU y los pasos que necesitan las GPUs costosas o las máquinas con mucha memoria, y pagar el costo de materialización asociado con la interrupción de la fusión. Para obtener más información, consulta Evita la fusión.
Ajuste adecuado de transmisión
En el caso de los trabajos de transmisión, puedes habilitar el ajuste correcto configurando la opción de canalización --experiments=enable_streaming_rightfitting.
El ajuste adecuado puede mejorar el rendimiento de tu canalización si incluye etapas con diferentes requisitos de recursos.
Ejemplo: Canalización con una etapa que requiere mucha CPU y otra que requiere GPU
Un ejemplo de una canalización que se puede beneficiar del ajuste adecuado es una que ejecuta una etapa que requiere mucha CPU, seguida de una etapa que requiere GPU. Sin el ajuste adecuado, se deberá configurar un solo grupo de trabajadores de GPU para ejecutar todas las etapas de la canalización, incluida la etapa que requiere mucha CPU. Esto puede generar un uso deficiente de los recursos de la GPU cuando el grupo de trabajadores ejecuta la etapa que requiere mucha CPU.
Si el ajuste adecuado está habilitado y se aplica una sugerencia de recursos al paso que requiere GPU, la canalización creará dos grupos separados, de modo que el grupo de trabajadores de CPU ejecute la etapa que requiere mucha CPU y el grupo de trabajadores de GPU ejecute la etapa que requiere GPU.
En el caso de esta canalización de ejemplo, la tabla de ajuste de escala automático muestra que el grupo de trabajadores que ejecuta la etapa con uso intensivo de la CPU, Pool 0, se escala verticalmente de forma inicial a 99 trabajadores y, luego, se reduce a 87 trabajadores. El grupo de trabajadores que ejecuta la etapa que requiere GPU, Pool 1, se amplía a 13 trabajadores:
El gráfico de uso de CPU muestra que los trabajadores de ambos grupos de trabajadores demuestran un uso general alto de la CPU:
Soluciona problemas de ajuste adecuado
En esta sección, se proporcionan instrucciones para solucionar problemas habituales relacionados con el ajuste adecuado.
La configuración no es válida
Cuando intentas usar el ajuste adecuado, se produce el siguiente error:
Workflow failed. Causes: One or more operations had an error: 'operation-OPERATION_ID':
[UNSUPPORTED_OPERATION] 'NUMBER vCpus with NUMBER MiB memory is
an invalid configuration for NUMBER count of 'GPU_TYPE' in family 'MACHINE_TYPE'.'.
Este error se produce cuando el tipo de GPU seleccionado no es compatible con el tipo de máquina seleccionado. Para resolver este error, selecciona un tipo de GPU y un tipo de máquina compatibles. Para obtener detalles sobre la compatibilidad, consulta Plataformas de GPU.
Verifica el ajuste adecuado
Para verificar que el ajuste correcto esté habilitado, consulta las métricas de ajuste de escala automático y verifica que la columna Worker pool esté visible y muestre diferentes grupos:
Rendimiento del ajuste adecuado de la transmisión
Es posible que las canalizaciones de transmisión con el ajuste adecuado habilitado no siempre tengan un mejor rendimiento que las canalizaciones sin el ajuste adecuado habilitado. Por ejemplo:
- La canalización usa más trabajadores
- La latencia del sistema es mayor o la capacidad de procesamiento es menor.
- Los tamaños de los grupos de trabajadores cambian con mayor frecuencia o no se estabilizan.
Si observas esto en tu canalización, puedes inhabilitar el ajuste a la derecha quitando la opción de canalización --experiments=enable_streaming_rightfitting. Además, las canalizaciones de transmisión con el ajuste adecuado habilitado que usan sugerencias de recursos de acelerador podrían usar más aceleradores de lo deseable. Si observas esto en tu canalización, puedes configurar una cantidad máxima de aceleradores que se usen en la canalización estableciendo la opción de canalización --experiments=max_num_accelerators=NUM.