Files
awesome-copilot/skills/cloud-design-patterns/references/messaging-integration.md
Fatih f8c2b32140 Add Cloud Design Patterns skill for distributed systems architecture (#942)
* Fatih: Add Cloud Design Patterns instructions for distributed systems architecture

* Convert Cloud Design Patterns from instruction to skill

* Update skills/cloud-design-patterns/SKILL.md

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* Update skills/cloud-design-patterns/references/reliability-resilience.md

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2026-03-12 11:53:00 +11:00

128 lines
4.5 KiB
Markdown

# Messaging & Integration Patterns
## Choreography Pattern
**Problem**: Central orchestrators create coupling and single points of failure.
**Solution**: Let individual services decide when and how a business operation is processed through event-driven collaboration.
**When to Use**:
- Loosely coupled microservices architectures
- Event-driven systems
- Avoiding central orchestration bottlenecks
**Implementation Considerations**:
- Use publish-subscribe messaging for event distribution
- Each service publishes domain events and subscribes to relevant events
- Implement saga pattern for complex workflows
- Ensure idempotency as events may be delivered multiple times
- Provide comprehensive logging and distributed tracing
## Claim Check Pattern
**Problem**: Large messages can overwhelm message infrastructure.
**Solution**: Split a large message into a claim check (reference) and a payload stored separately.
**When to Use**:
- Messages exceed messaging system size limits
- Reducing message bus load
- Handling large file transfers asynchronously
**Implementation Considerations**:
- Store payload in blob storage or database
- Send only reference/URI through message bus
- Implement expiration policies for stored payloads
- Handle access control for payload storage
- Consider costs of storage vs message transmission
## Competing Consumers Pattern
**Problem**: Single consumer may not keep up with message volume.
**Solution**: Enable multiple concurrent consumers to process messages from the same messaging channel.
**When to Use**:
- High message throughput requirements
- Scaling message processing horizontally
- Load balancing across multiple instances
**Implementation Considerations**:
- Ensure messages can be processed in any order
- Use competing consumer queues (Service Bus, RabbitMQ)
- Implement idempotency for message handlers
- Handle poison messages with retry and dead-letter policies
- Scale consumer count based on queue depth
## Messaging Bridge Pattern
**Problem**: Different systems use incompatible messaging technologies.
**Solution**: Build an intermediary to enable communication between messaging systems that are otherwise incompatible.
**When to Use**:
- Migrating between messaging systems
- Integrating with legacy systems
- Connecting cloud and on-premises messaging
**Implementation Considerations**:
- Transform message formats between systems
- Handle protocol differences
- Maintain message ordering if required
- Implement error handling and retry logic
- Monitor bridge performance and health
## Pipes and Filters Pattern
**Problem**: Complex processing tasks are difficult to maintain and reuse.
**Solution**: Break down a task that performs complex processing into a series of separate, reusable elements (filters) connected by channels (pipes).
**When to Use**:
- Processing data streams with multiple transformations
- Building reusable processing components
- Enabling parallel processing of independent operations
**Implementation Considerations**:
- Each filter performs a single transformation
- Connect filters using message queues or streams
- Enable parallel execution where possible
- Handle errors within filters or at pipeline level
- Support filter composition and reordering
## Publisher-Subscriber Pattern
**Problem**: Applications need to broadcast information to multiple interested consumers.
**Solution**: Enable an application to announce events to multiple consumers asynchronously, without coupling senders to receivers.
**When to Use**:
- Broadcasting events to multiple interested parties
- Decoupling event producers from consumers
- Implementing event-driven architectures
**Implementation Considerations**:
- Use topic-based or content-based subscriptions
- Ensure message delivery guarantees match requirements
- Implement subscription filters for selective consumption
- Handle consumer failures without affecting publishers
- Consider message ordering requirements per subscriber
## Scheduler Agent Supervisor Pattern
**Problem**: Distributed actions need coordination and monitoring.
**Solution**: Coordinate a set of actions across distributed services and resources with a supervisor that monitors and manages the workflow.
**When to Use**:
- Orchestrating multi-step workflows
- Coordinating distributed transactions
- Implementing resilient long-running processes
**Implementation Considerations**:
- Scheduler dispatches tasks to agents
- Agents perform work and report status
- Supervisor monitors progress and handles failures
- Implement compensation logic for failed steps
- Maintain state for workflow recovery