Compartir vía


Procedimientos recomendados para la comunicación en cola

En este tema se proporcionan algunos procedimientos recomendados para la comunicación en cola en la infraestructura Windows Communication Foundation (WCF). Las secciones siguientes discuten los procedimientos recomendados desde una perspectiva del escenario.

Mensajería en cola rápida y eficiente

Para los escenarios que requieren la separación que proporciona la mensajería en cola y una mensajería rápida y de alto rendimiento con garantías de optimización, utilice una cola no transaccional y establezca la propiedad ExactlyOnce en false.

Además, puede decidir no incurrir en el costo de escrituras en disco estableciendo la propiedad Durable en false.

La seguridad afecta al rendimiento. Para obtener más información, consulte Consideraciones sobre el rendimiento.

Mensajería en cola fiable de un extremo a otro

Las secciones siguientes describen los procedimientos recomendados para escenarios que requieren una mensajería fiable de un extremo a otro.

Transferencia fiable básica

Para obtener una fiabilidad de un extremo a otro, establezca la propiedad ExactlyOnce en true para asegurar la transferencia. La propiedad Durable puede establecerse en true o false en función de sus requisitos (el valor predeterminado es true). Generalmente, la propiedad Durable está establecida en true como parte de la fiabilidad de un extremo a otro. El compromiso es proporcionar un costo de rendimiento, pero hace el mensaje durable para que no se pierda el mensaje si un administrador de cola se bloquea.

Uso de transacciones

Debe usar transacciones para garantizar la confiabilidad de un extremo a otro. Las garantías deExactlyOnce solo aseguran que los mensajes se entreguen a la cola de destino. Para garantizar que se reciba el mensaje, utilice transacciones. Sin transacciones, si el servicio se bloquea, pierde el mensaje que se entrega pero realmente se entrega a la aplicación.

Uso de colas de mensajes no enviados

Las colas de mensajes no enviados aseguran que reciba una notificación si no se pudo entregar un mensaje a la cola de destino. Puede utilizar la cola de mensajes no enviados proporcionada por el sistema o una cola de mensajes no enviados personalizada. En general, utilizar una cola de mensajes no enviados personalizada es mejor porque le permite enviar mensajes no enviados de una aplicación en una cola de mensajes no enviados única. De lo contrario, todos los mensajes no enviados que ocurran para todas las aplicaciones que se ejecuten en el sistema se entregan a una cola única. Cada aplicación debe buscar a continuación en la cola de mensajes no enviados para encontrar los mensajes no enviados pertinentes para esa aplicación. A veces, utilizar una cola de mensajes no enviados personalizada no es factible, como cuando se usa MSMQ 3.0.

No se recomienda desactivar las colas de mensajes no enviados para la comunicación fiable de un extremo a otro.

Para obtener más información, consulte Uso de colas de mensajes fallidos para controlar los errores en la transferencia mensajes.

Uso de control de mensajes dudosos

El control de mensajes dudosos proporciona la capacidad de recuperarse del error de procesamiento de mensajes.

Al utilizar la característica de control de mensajes dudosos, asegúrese de que la propiedad ReceiveErrorHandling está establecida en el valor adecuado. Establecerla en Drop implica que los datos se pierdan. Por otro lado, establecerla en Fault produce un error en el host de servicios cuando detecta un mensaje dudoso. Utilizar MSMQ 3.0, Fault es la mejor opción para evitar la pérdida de datos y quitar el mensaje dudoso. Con MSMQ 4.0, Move es el enfoque recomendado. Move mueve un mensaje dudoso fuera de la cola para que el servicio pueda continuar procesando los nuevos mensajes. El servicio del mensaje dudoso puede procesar a continuación el mensaje dudoso por separado.

Para obtener más información, consulte Control de mensajes dudosos.

Obtener un alto rendimiento

Para lograr un alto rendimiento en un solo punto de conexión, utilice lo siguiente:

  • Procesamiento por lotes con transacciones El procesamiento por lotes con transacciones garantiza que muchos mensajes se puedan leer en una transacción única. Esto optimiza las confirmaciones de transacciones, aumentando el rendimiento total. El costo del procesamiento por lotes es que si se produce un error en un mensaje único dentro de un lote, se deshace el lote completo y se deben procesar los mensajes de uno en uno hasta que sea seguro de nuevo el procesamiento por lotes. En la mayoría de los casos, los mensajes dudosos son raros, así que el procesamiento por lotes es la forma preferida de aumentar el rendimiento del sistema, particularmente cuando se tienen otros administradores de recursos que participan en la transacción. Para obtener más información, consulte Procesamiento por lotes de mensajes en una transacción.

  • Simultaneidad. La simultaneidad aumenta el rendimiento, pero también afecta a la contención a los recursos compartidos. Para obtener más información, consulte Simultaneidad.

  • Limitación de peticiones. Para un rendimiento óptimo, limite el número de mensajes en el conductor del distribuidor. Para obtener un ejemplo de cómo hacerlo, consulte Limitación.

Al utilizar el procesamiento por lotes, sea consciente que la simultaneidad y la limitación de peticiones se traducen en los lotes simultáneos.

Para obtener un rendimiento y una disponibilidad mayores, use una granja de servicios WCF para realizar procesos de lectura de la cola. Esto requiere que todos estos servicios expongan el mismo contrato en el mismo extremo. El enfoque del conjunto funciona mejor para las aplicaciones que tienen tasas altas de producción de mensajes porque permite a varios servicios que lean desde la misma cola.

Al utilizar los conjuntos, sea consciente de que MSMQ 3.0 no admite las lecturas con transacciones remotas. MSMQ 4.0 admite las lecturas con transacciones remotas.

Para obtener más información, consulte Procesamiento por lotes de mensajes en una transacción.

Puesta en cola con la unidad de semántica de trabajo

En algunos escenarios un grupo de mensajes en una cola se puede relacionar y, por consiguiente, la clasificación de estos mensajes es significativa. En tales escenarios, procese juntos un grupo de mensajes relacionados como una unidad única: o se procesan todos los mensajes correctamente o no se procesa ninguno. Para implementar tal comportamiento, utilice sesiones con colas.

Para obtener más información, consulte Agrupación de mensajes en cola en una sesión.

Correlación de mensajes de solicitud-respuesta

Aunque las colas son típicamente unidireccionales, en algunos escenarios puede querer correlacionar una respuesta recibida con una solicitud enviada anteriormente. Si requiere dicha correlación, se recomienda que aplique su propio encabezado de mensaje SOAP que contiene información de correlación con el mensaje. Normalmente, el remitente adjunta este encabezado al mensaje y el receptor, tras procesar el mensaje y responder con un nuevo mensaje en una cola de respuesta, adjunta el encabezado del mensaje del remitente que contiene la información de la correlación al mensaje de solicitud para que el remitente pueda identificar el mensaje de respuesta.

Integración en aplicaciones que no son WCF

Use la clase MsmqIntegrationBinding para integrar servicios o clientes de WCF con servicios o clientes que no sean de WCF. La aplicación que no sea de WCF podrá ser una aplicación MSMQ que se haya escrito mediante System.Messaging, COM+, Visual Basic o C++.

Al utilizar MsmqIntegrationBinding, sea consciente de lo siguiente:

  • Los cuerpo de los mensajes WCF de no son iguales que los de los mensajes MSMQ. Al enviar un mensaje WCF mediante un enlace en cola, el cuerpo de este se coloca dentro de un mensaje MSMQ. La infraestructura de MSMQ es ajena a esta información adicional; solo ve el mensaje de MSMQ.

  • MsmqIntegrationBinding admite los tipos de serialización populares. Se basa en el tipo de serialización, el tipo de cuerpo del mensaje genérico, MsmqMessage<T>, toma diferentes tipos de parámetros. Por ejemplo, ByteArray requiere MsmqMessage\<byte[]>Stream y MsmqMessage<Stream> requiere .

  • Puede usar un proceso de serialización XML para especificar el tipo conocido mediante el atributo KnownTypes del elemento <behavior>, que se usará para determinar cómo debe deserializarse el mensaje XML.

Consulte también