Hay varios blogs que afirman clasificar las transformaciones SSIS en bloqueadas (asíncronas), no bloqueadas (síncronas) y parcialmente bloqueadas (asíncronas).
Al analizar la pregunta específica: ¿La multidifusión es síncrona (sin bloqueo) o asíncrona (parcialmente bloqueada)?
Un recurso afirma asíncrono: "La Multidifusión es una transformación asincrónica (también conocida como bloqueo parcial)" : http://social.technet.microsoft.com/wiki/contents/articles/7392.ssis-multicast-transformation.aspx
y otro sincrónico: https://jorgklein.com/2009/04/14/ssis-lookup-is-case-sensitive/
Otros recursos afirman que la transformación de limpieza DQS es una transformación sin bloqueo, pero me parece que está bloqueando parcialmente.
No responda con un enlace a una lista de transformaciones clasificadas por tipo. Con suerte, la respuesta a esta pregunta permitirá un método más riguroso para PROBAR una respuesta correcta.
Como las transformaciones de bloqueo y bloqueo parcial moverán los datos a nuevos buffers en lugar de los no bloqueadores que operan en el buffer en su lugar, sospecho que la solución será observar la creación del buffer durante la ejecución de la transformación, pero no estoy seguro (a ) si esto producirá la respuesta definitiva y (b) cómo hacerlo.
Creo que una transformación sin bloqueo no hará que comience un nuevo árbol de ejecución, por lo que es posible que la respuesta se encuentre en el registro de PipelineExectionTrees y PipelineExecutionPlan. Esto puede diferenciar entre síncrono y asíncrono, pero no puede diferenciar entre bloqueo parcial y bloqueo total.
fuente
Respuestas:
Una operación que está bloqueando debe esperar hasta que se hayan visto y manejado todas las filas antes de que pueda comenzar a llenar los buffers.
Una operación que bloquea parcialmente escribe datos en nuevos buffers, que solo son manejados por la siguiente operación una vez que se rellena cada buffer (generalmente menos de 10,000 filas).
Una operación que no es de bloqueo puede hacer que la operación posterior funcione en el mismo búfer, ya que se maneja cada fila.
Pero muchos textos se referirán a 'parcialmente bloqueado' como 'no bloqueante', ya que el comportamiento está mucho más cerca de 'no bloquear' que 'bloquear'.
Debería poder saber qué está sucediendo observando el flujo de datos y ver cuándo aumentan los números en cada punto.
fuente