![]() |
VOOZH | about |
dotnet add package Yautbox.Mysql --version 1.1.1
NuGet\Install-Package Yautbox.Mysql -Version 1.1.1
<PackageReference Include="Yautbox.Mysql" Version="1.1.1" />
<PackageVersion Include="Yautbox.Mysql" Version="1.1.1" />Directory.Packages.props
<PackageReference Include="Yautbox.Mysql" />Project file
paket add Yautbox.Mysql --version 1.1.1
#r "nuget: Yautbox.Mysql, 1.1.1"
#:package Yautbox.Mysql@1.1.1
#addin nuget:?package=Yautbox.Mysql&version=1.1.1Install as a Cake Addin
#tool nuget:?package=Yautbox.Mysql&version=1.1.1Install as a Cake Tool
MySQL infrastructure provider for Yautbox. It stores outbox messages in MySQL, applies schema migrations on startup, and supports distributed locks for sequential execution.
ExecutionPolicy.SequentialNuGet (if published):
dotnet add package Yautbox.Mysql
From source:
dotnet add <your-app>.csproj reference src/Yautbox.Mysql/Yautbox.Mysql.csproj
using Microsoft.Extensions.DependencyInjection;
using Yautbox.Extensions.Ioc;
using Yautbox.Mysql.Extensions;
services.AddOutbox(builder => builder.UseMysql(
connectionString: "Server=localhost;Database=yautbox;User ID=root;Password=pass;"));
services.AddOutboxHandler<OrderPlaced, OrderPlacedHandler>();
MysqlStoreOptions:
SchemaName (default: "outbox")CleanupBatchSize (default: 1000)ConfigureJsonOptions (customize JsonSerializerOptions)Example:
using System.Text.Json;
using Yautbox.Mysql.Extensions;
using Yautbox.Mysql.Extensions.Configurator;
services.AddOutbox(builder => builder.UseMysql(
connectionString: "...",
options: new MysqlStoreOptions
{
SchemaName = "messaging",
CleanupBatchSize = 2000,
ConfigureJsonOptions = (json, _) => json.PropertyNamingPolicy = JsonNamingPolicy.CamelCase
}));
If you need custom connection creation (for example, Azure SQL with custom tokens), register your own factory and use the generic overload:
using Yautbox.Mysql.Extensions;
using Yautbox.Mysql.Infrastructure.Database;
public sealed class MyConnectionFactory : IOutboxConnectionFactory
{
public string GetConnectionString() => "...";
public Task<DbConnection> GetConnectionAsync(CancellationToken ct) => /* ... */;
}
services.AddOutbox(builder => builder.UseMysql<MyConnectionFactory>());
This provider runs FluentMigrator migrations on startup and waits for readiness before handlers begin polling. The database user must have permissions to create schemas and tables.
ExecutionPolicy.Sequential uses a MySQL distributed lock to ensure single active processing per identifier.DeletePolicy.Safe marks records as deleted; cleanup is performed by the background cleaner when BackupInterval is set.| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.