Beckett.Dashboard
0.14.2
See the version list below for details.
dotnet add package Beckett.Dashboard --version 0.14.2
NuGet\Install-Package Beckett.Dashboard -Version 0.14.2
<PackageReference Include="Beckett.Dashboard" Version="0.14.2" />
paket add Beckett.Dashboard --version 0.14.2
#r "nuget: Beckett.Dashboard, 0.14.2"
// Install Beckett.Dashboard as a Cake Addin #addin nuget:?package=Beckett.Dashboard&version=0.14.2 // Install Beckett.Dashboard as a Cake Tool #tool nuget:?package=Beckett.Dashboard&version=0.14.2
Beckett
Event sourcing is a powerful pattern for building applications but reading and writing events using an event store is only half of the equation. Beckett aims to fill in the gaps:
- Subscriptions - subscribe to messages and process them in order by stream
- Projections, read models, event handlers - add asynchronous, event-driven behavior to your applications
- Horizontal scalability - use auto-scaling to have as many workers as needed processing messages in parallel where the work is distributed automatically across all available nodes without needing to manage the distribution by way of consumer groups or similar mechanisms
- Retries - built-in retry support for failed messages - since messages are processed in order by stream per subscription, a failed message only blocks a single stream for a subscription at a time and the rest of the streams can continue processing for that subscription
- Scheduled - schedule messages to be sent at a future time with cancellation support
- Open Telemetry - built-in support to provide tracing and metrics
- Dashboard - browse messages, retry failed subscription checkpoints
- Bring Your Own Event Store - Beckett provides a simple Postgres-based message store or use your own by implementing the
IMessageStorage
interface
Example
We are building a warehouse management system and we need to allocate inventory to orders. The requirements are that allocation occurs when an item is added to an order:
using Beckett;
using Beckett.Database;
var builder = Host.CreateApplicationBuilder(args);
var connectionString = builder.Configuration.GetConnectionString("InventoryAllocation")!;
//ensure the Beckett database schema is up to date
await BeckettDatabase.Migrate(connectionString);
//configure the data source with support for Beckett
builder.Services.AddNpgsqlDataSource(connectionString, options => options.AddBeckett());
//register the subscription handler in the container
builder.Services.AddTransient<OrderItemAddedHandler>();
//add Beckett support to the host for the InventoryAllocation subscription group
var beckett = builder.AddBeckett(
options => { options.WithSubscriptionGroup("InventoryAllocation"); }
);
//map message types
beckett.Map<OrderItemAdded>("order_item_added");
beckett.Map<InventoryAllocated>("inventory_allocated");
//add subscription handler
beckett.AddSubscription("order-item-inventory-allocation")
.Message<OrderItemAdded>()
.Handler<OrderItemAddedHandler>((handler, message, token) => handler.Handle(message, token));
var host = builder.Build();
host.Run();
public record OrderItemAdded(Guid OrderId, Guid ProductId, int Quantity);
public record InventoryAllocated(Guid ProductId, Guid OrderId, int Quantity);
public class OrderItemAddedHandler(IMessageStore messageStore)
{
public async Task Handle(OrderItemAdded message, CancellationToken cancellationToken)
{
await messageStore.AppendToStream(
$"inventory-{message.ProductId}",
ExpectedVersion.Any,
new InventoryAllocated(message.ProductId, message.OrderId, message.Quantity),
cancellationToken
);
}
}
In this example application we are handling the OrderItemAdded
event with the OrderItemAddedHandler
class. The host
has been configured to use the InventoryAllocation
subscription group, and there can be as many instances of this host
running as necessary and the work will be divided among them automatically allowing you to take advantage of auto
scaling without limits. The handler will receive all OrderItemAdded
messages written to the message store since it is
subscribed to that type in the AddSubscription
call. When a message is received it is dispatched to the handler which
then writes an InventoryAllocated
event to an Inventory
stream to track allocated product inventory.
One of the guiding design principles of Beckett is keeping a minimal footprint - there should be as few references to
Beckett-provided types in application code as possible. Subscription handlers are registered as inline delegates that
can refer to handler instances that are resolved from the container or static functions. The only type from Beckett used
in the application code in this sample is IMessageStore
which itself is optional if you're using your own message
store.
The call to BeckettDatabase.Migrate
in the example is applying any outstanding migrations to the database that are
required by Beckett. If you wish to run the migrations separately using Flyway or similar tools then you can use the
dump-migrations
shell script supplied in the root of the directory to create a single SQL file:
./dump-migrations.sh beckett 001.sql
In this case beckett
is the schema you'd like to use in your database for the tables, functions, and types that
Beckett uses and 001.sql
is the path of the file you'd like to create.
Dashboard
Beckett comes batteries-included with a dashboard to provide visibility into your system while it's running, retry failed checkpoints, and so on:
<img width="1575" alt="Beckett Dashboard" src="https://github.com/user-attachments/assets/0dc5a445-111b-4552-a639-36b37779d094">
Adding the Beckett dashboard to an ASP.NET Core application is simple:
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.MapBeckettDashboard("/beckett");
app.Run();
In this example, the dashboard will be available at http://localhost:<port>/beckett
and can be further configured
using standard ASP.NET Core route group configuration options - authorization, etc...
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
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 |
---|---|---|
0.16.12 | 89 | 1/23/2025 |
0.16.11 | 118 | 1/22/2025 |
0.16.10 | 108 | 1/20/2025 |
0.16.8 | 164 | 1/16/2025 |
0.16.7 | 177 | 1/15/2025 |
0.16.6 | 36 | 1/14/2025 |
0.16.5 | 114 | 1/10/2025 |
0.16.4 | 88 | 1/10/2025 |
0.16.3 | 185 | 1/4/2025 |
0.16.2 | 103 | 1/4/2025 |
0.16.1 | 183 | 1/1/2025 |
0.16.0 | 102 | 1/1/2025 |
0.15.0 | 121 | 12/31/2024 |
0.14.4 | 80 | 12/17/2024 |
0.14.3 | 91 | 12/16/2024 |
0.14.2 | 86 | 12/16/2024 |
0.14.1 | 88 | 12/12/2024 |
0.14.0 | 87 | 12/12/2024 |
0.13.1 | 899 | 11/15/2024 |
0.13.0 | 104 | 11/8/2024 |
0.12.6 | 448 | 11/1/2024 |
0.12.5 | 130 | 10/31/2024 |
0.12.4 | 178 | 10/30/2024 |
0.12.3 | 115 | 10/29/2024 |
0.12.2 | 139 | 10/29/2024 |
0.12.1 | 693 | 10/28/2024 |
0.12.0 | 103 | 10/28/2024 |
0.11.12 | 132 | 10/25/2024 |
0.11.11 | 193 | 10/22/2024 |
0.11.10 | 314 | 10/18/2024 |
0.11.9 | 131 | 10/18/2024 |
0.11.8 | 131 | 10/18/2024 |
0.11.7 | 131 | 10/18/2024 |
0.11.6 | 146 | 10/17/2024 |
0.11.5 | 99 | 10/17/2024 |
0.11.4 | 86 | 10/17/2024 |
0.11.3 | 84 | 10/17/2024 |
0.11.2 | 228 | 10/13/2024 |
0.11.1 | 132 | 10/12/2024 |
0.11.0 | 121 | 10/11/2024 |
0.10.4 | 100 | 10/8/2024 |
0.10.3 | 106 | 10/7/2024 |
0.10.2 | 82 | 10/7/2024 |
0.10.1 | 85 | 10/7/2024 |
0.10.0 | 86 | 10/7/2024 |
0.9.17 | 1,699 | 9/14/2024 |
0.9.16 | 129 | 9/14/2024 |
0.9.15 | 193 | 9/13/2024 |
0.9.14 | 112 | 9/13/2024 |
0.9.13 | 270 | 9/7/2024 |
0.9.12 | 102 | 9/6/2024 |
0.9.11 | 258 | 9/5/2024 |
0.9.10 | 350 | 9/4/2024 |
0.9.9 | 386 | 8/29/2024 |
0.9.8 | 108 | 8/29/2024 |
0.9.7 | 238 | 8/28/2024 |
0.9.6 | 203 | 8/27/2024 |
0.9.5 | 106 | 8/27/2024 |
0.9.4 | 547 | 8/16/2024 |
0.9.3 | 584 | 8/14/2024 |
0.9.2 | 375 | 8/12/2024 |
0.9.1 | 251 | 8/8/2024 |
0.9.0 | 299 | 8/5/2024 |
0.8.13 | 95 | 8/2/2024 |
0.8.12 | 88 | 8/2/2024 |
0.8.11 | 405 | 7/26/2024 |
0.8.10 | 89 | 7/25/2024 |
0.8.9 | 79 | 7/25/2024 |
0.8.8 | 285 | 7/21/2024 |
0.8.7 | 148 | 7/19/2024 |
0.8.6 | 102 | 7/19/2024 |
0.8.5 | 174 | 7/16/2024 |
0.8.4 | 118 | 7/16/2024 |
0.8.3 | 108 | 7/16/2024 |
0.8.2 | 177 | 7/13/2024 |
0.8.1 | 87 | 7/13/2024 |
0.8.0 | 103 | 7/13/2024 |
0.7.9 | 116 | 7/12/2024 |
0.7.8 | 92 | 7/12/2024 |
0.7.7 | 110 | 7/11/2024 |
0.7.6 | 122 | 7/10/2024 |
0.7.5 | 92 | 7/10/2024 |
0.7.4 | 90 | 7/10/2024 |
0.7.3 | 94 | 7/10/2024 |
0.7.2 | 85 | 7/9/2024 |
0.7.1 | 118 | 7/9/2024 |
0.7.0 | 93 | 7/9/2024 |
0.6.6 | 101 | 7/8/2024 |
0.6.5 | 90 | 7/7/2024 |
0.6.4 | 110 | 7/7/2024 |