|
Add this skill
npx mdskills install sickn33/azure-eventhub-rustWell-structured SDK reference with clear examples, but lacks agent-specific instructions
1---2name: azure-eventhub-rust3description: |4 Azure Event Hubs SDK for Rust. Use for sending and receiving events, streaming data ingestion.5 Triggers: "event hubs rust", "ProducerClient rust", "ConsumerClient rust", "send event rust", "streaming rust".6package: azure_messaging_eventhubs7---89# Azure Event Hubs SDK for Rust1011Client library for Azure Event Hubs — big data streaming platform and event ingestion service.1213## Installation1415```sh16cargo add azure_messaging_eventhubs azure_identity17```1819## Environment Variables2021```bash22EVENTHUBS_HOST=<namespace>.servicebus.windows.net23EVENTHUB_NAME=<eventhub-name>24```2526## Key Concepts2728- **Namespace** — container for Event Hubs29- **Event Hub** — stream of events partitioned for parallel processing30- **Partition** — ordered sequence of events31- **Producer** — sends events to Event Hub32- **Consumer** — receives events from partitions3334## Producer Client3536### Create Producer3738```rust39use azure_identity::DeveloperToolsCredential;40use azure_messaging_eventhubs::ProducerClient;4142let credential = DeveloperToolsCredential::new(None)?;43let producer = ProducerClient::builder()44 .open("<namespace>.servicebus.windows.net", "eventhub-name", credential.clone())45 .await?;46```4748### Send Single Event4950```rust51producer.send_event(vec![1, 2, 3, 4], None).await?;52```5354### Send Batch5556```rust57let batch = producer.create_batch(None).await?;58batch.try_add_event_data(b"event 1".to_vec(), None)?;59batch.try_add_event_data(b"event 2".to_vec(), None)?;6061producer.send_batch(batch, None).await?;62```6364## Consumer Client6566### Create Consumer6768```rust69use azure_messaging_eventhubs::ConsumerClient;7071let credential = DeveloperToolsCredential::new(None)?;72let consumer = ConsumerClient::builder()73 .open("<namespace>.servicebus.windows.net", "eventhub-name", credential.clone())74 .await?;75```7677### Receive Events7879```rust80// Open receiver for specific partition81let receiver = consumer.open_partition_receiver("0", None).await?;8283// Receive events84let events = receiver.receive_events(100, None).await?;85for event in events {86 println!("Event data: {:?}", event.body());87}88```8990### Get Event Hub Properties9192```rust93let properties = consumer.get_eventhub_properties(None).await?;94println!("Partitions: {:?}", properties.partition_ids);95```9697### Get Partition Properties9899```rust100let partition_props = consumer.get_partition_properties("0", None).await?;101println!("Last sequence number: {}", partition_props.last_enqueued_sequence_number);102```103104## Best Practices1051061. **Reuse clients** — create once, send many events1072. **Use batches** — more efficient than individual sends1083. **Check batch capacity** — `try_add_event_data` returns false when full1094. **Process partitions in parallel** — each partition can be consumed independently1105. **Use consumer groups** — isolate different consuming applications1116. **Handle checkpointing** — use `azure_messaging_eventhubs_checkpointstore_blob` for distributed consumers112113## Checkpoint Store (Optional)114115For distributed consumers with checkpointing:116117```sh118cargo add azure_messaging_eventhubs_checkpointstore_blob119```120121## Reference Links122123| Resource | Link |124|----------|------|125| API Reference | https://docs.rs/azure_messaging_eventhubs |126| Source Code | https://github.com/Azure/azure-sdk-for-rust/tree/main/sdk/eventhubs/azure_messaging_eventhubs |127| crates.io | https://crates.io/crates/azure_messaging_eventhubs |128
Full transparency — inspect the skill content before installing.