MakoIoT.Device.Services.Messaging
1.0.63.58350
dotnet add package MakoIoT.Device.Services.Messaging --version 1.0.63.58350
NuGet\Install-Package MakoIoT.Device.Services.Messaging -Version 1.0.63.58350
<PackageReference Include="MakoIoT.Device.Services.Messaging" Version="1.0.63.58350" />
paket add MakoIoT.Device.Services.Messaging --version 1.0.63.58350
#r "nuget: MakoIoT.Device.Services.Messaging, 1.0.63.58350"
// Install MakoIoT.Device.Services.Messaging as a Cake Addin #addin nuget:?package=MakoIoT.Device.Services.Messaging&version=1.0.63.58350 // Install MakoIoT.Device.Services.Messaging as a Cake Tool #tool nuget:?package=MakoIoT.Device.Services.Messaging&version=1.0.63.58350
Mako-IoT.Device.Services.Messaging
Message bus with pub-sub and stronly typed data contracts.
Main concepts
Message routing
There are two type of routes:
- Broadcast messages are published under topics and delivered to one or more subscribers. This is usually used for propagating events.
- Direct message is delivered to single recipient. This is usually used for sending commands. Routing is done automatically based on message types.
Message contracts
Message contracts are classes that implement IMessage interface. MessageType must be set to full type name of the class.
public class BlinkCommand : IMessage
{
public BlinkCommand()
{
MessageType = this.GetType().FullName;
}
public bool LedOn { get; set; }
public string MessageType { get; set; }
}
Consumers
Messages are delivered to consumer classes.
public class BlinkCommandConsumer : IConsumer
{
private readonly IBlinker _blinker;
private readonly ILogger _logger;
public BlinkCommandConsumer(IBlinker blinker, ILogger logger)
{
_blinker = blinker;
_logger = logger;
}
public void Consume(ConsumeContext context)
{
var cmd = (BlinkCommand)context.Message;
_logger.LogDebug($"Setting LED to {cmd.LedOn}");
_blinker.Set(cmd.LedOn);
}
}
Consumers are registered against message types in DeviceBuilder with AddDirectMessageConsumer or AddSubscriptionConsumer
public static void Main()
{
DeviceBuilder.Create()
.AddMessageBus(o =>
{
o.AddDirectMessageConsumer(typeof(BlinkCommand), typeof(BlinkCommandConsumer), ConsumeStrategy.LastMessageWins);
})
//[...]
Consume strategies
Consuming multiple messages of same type (i.e. by single consumer) may be done in one of three fashions:
- Synchronously - receiving subsequent messages is blocked until current message ends processing.
- FIFO - received messages are put onto a queue and processed in order.
- Last Message Wins - the most recent message is processed and older unprocessed messages are discarded. This equivalent to bulkhead resilience pattern with single concurrent action.
Sending messages
bus.Send(msg, "device1"); //sends direct message to "device1"
bus.Publish(msg); //publishes broadcast message
Interoperability with .NET
With .NET implementation of message bus you can easily communicate between nanoFramework devices and .NET services or application. Data contract classes can be shared across both parties. See messaging sample.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net is compatible. |
-
- MakoIoT.Device.Services.Interface (>= 1.0.48.22567)
- MakoIoT.Device.Utilities.String (>= 1.0.37.35071)
- nanoFramework.CoreLibrary (>= 1.15.5)
- nanoFramework.DependencyInjection (>= 1.1.11)
- nanoFramework.Json (>= 2.2.152)
- nanoFramework.System.Collections (>= 1.5.45)
- nanoFramework.System.IO.Streams (>= 1.1.59)
- nanoFramework.System.Text (>= 1.2.54)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.63.58350 | 87 | 11/28/2024 |
1.0.62.39147 | 75 | 11/27/2024 |
1.0.61.65061 | 88 | 11/26/2024 |
1.0.60.8871 | 88 | 11/25/2024 |
1.0.59.39628 | 86 | 11/19/2024 |
1.0.58.46908 | 92 | 10/31/2024 |
1.0.57.41830 | 131 | 10/19/2024 |
1.0.56.35619 | 131 | 10/18/2024 |
1.0.55.53831 | 92 | 10/16/2024 |
1.0.54.17802 | 88 | 9/30/2024 |
1.0.53.63834 | 92 | 9/26/2024 |
1.0.52.58630 | 102 | 9/20/2024 |
1.0.51.33981 | 119 | 9/12/2024 |
1.0.50.7227 | 109 | 9/5/2024 |
1.0.49.65299 | 108 | 8/28/2024 |
1.0.48.4709 | 106 | 8/27/2024 |
1.0.47.29483 | 126 | 8/11/2024 |
1.0.46.26755 | 114 | 8/10/2024 |
1.0.45.44465 | 83 | 8/5/2024 |
1.0.44.59575 | 112 | 6/12/2024 |
1.0.43.12089 | 112 | 5/18/2024 |
1.0.42.33950 | 121 | 5/17/2024 |
1.0.41.841 | 133 | 4/9/2024 |
1.0.40.35009 | 113 | 4/8/2024 |
1.0.39.27363 | 122 | 4/3/2024 |
1.0.38.33544 | 122 | 3/22/2024 |
1.0.37.6157 | 112 | 3/21/2024 |
1.0.36.17910 | 191 | 1/6/2024 |
1.0.35.19216 | 147 | 12/30/2023 |
1.0.34.20615 | 161 | 12/2/2023 |
1.0.33.8822 | 144 | 12/1/2023 |
1.0.32.53741 | 156 | 11/17/2023 |
1.0.31.63629 | 133 | 11/11/2023 |
1.0.30.34678 | 132 | 11/11/2023 |
1.0.29.45728 | 131 | 10/9/2023 |
1.0.28.38941 | 153 | 10/6/2023 |
1.0.27.18901 | 149 | 10/4/2023 |
1.0.25.29211 | 186 | 5/29/2023 |
1.0.24.44332 | 164 | 5/25/2023 |
1.0.20.4309 | 152 | 5/22/2023 |
1.0.19.42541 | 156 | 5/22/2023 |