Kafka.SignalR
1.0.1
dotnet add package Kafka.SignalR --version 1.0.1
NuGet\Install-Package Kafka.SignalR -Version 1.0.1
<PackageReference Include="Kafka.SignalR" Version="1.0.1" />
<PackageVersion Include="Kafka.SignalR" Version="1.0.1" />
<PackageReference Include="Kafka.SignalR" />
paket add Kafka.SignalR --version 1.0.1
#r "nuget: Kafka.SignalR, 1.0.1"
#addin nuget:?package=Kafka.SignalR&version=1.0.1
#tool nuget:?package=Kafka.SignalR&version=1.0.1
Kafka.SignalR
Real-time Kafka Message Delivery to Frontend Using SignalR
Overview
In this guide, we will demonstrate how to set up a Kafka.SingalR in your application and deliver Kafka messages directly to your frontend client using SignalR. This approach enables real-time updates and seamless communication between your backend and frontend.
Feature
- Connect Kafka as a Consumer: Establish a connection to Kafka and consume messages from one or more topics.
- Deliver Kafka Messages Directly to UI Client: Use SignalR to push Kafka messages to the frontend in real-time.
- Support for Multiple Kafka Topics: Easily connect and consume messages from multiple Kafka topics.
Usage
- Install the
Kafka.SignalR
NuGet package.
- .NET CLI
dotnet add package Kafka.SignalR --version 1.0.1
- PackageManager
Install-Package Kafka.SignalR -Version 1.0.1
- In
ConfigureServices
inStartup.cs
, configure with.AddKafkaSignalR(Configuration.GetSection("Kafka"))
: - In
Configure
inStartup.cs
, configure withendpoints.MapHub<KafkaSignalRHub>(Configuration["Kafka:Hub"])
Configuration
Simple configuration:
services.AddKafkaSignalR(Configuration.GetSection("Kafka"))
app.UseEndpoints(endpoints =>
{
endpoints
.MapHub<KafkaSignalRHub>(Configuration["Kafka:Hub"])
endpoints
.MapGet("/", async context => {
await context.Response.WriteAsync("Running Kafka Service....");
});
});
Simple appsettings.json
"Kafka": {
"Hub": "kafka/hubService",
"Topics": "MyTopic",
"GroupId": "myFirstApp",
"BootstrapServers": "localhost:9092",
"SecurityProtocol": "PlainText", //Ssl or PlainText
"EnableAutoCommit": "true",
"AutoCommitIntervalMs": "600000",
//If Ssl than configure below
"SslCaLocation": "",
"SslCertificateLocation": "",
"SslKeyLocation": ""
},
SignalR Client
const connection = new signalR.HubConnectionBuilder().withUrl("https://localhost:44363/kafka/hubService").build();
connection.on("RelayMessage", function (topicName,message) {
// your code
});
connection.start().then(function () {
//subscribe to kafka topics
connection.invoke("Subscribe", "MyTopic");
connection.invoke("Subscribe", "MyTopic1");
}).catch(function (err) {
return console.error(err.toString());
});
Override Message Processing (NEW)
If user want to override message processing before delivering it to the SignalR Client. Please follow the below approach.
public class KafkaMessageProcessService: IKafkaMessageProcessService
{
public string ProcessMessage(string message)
{
string processedMessage = message;
//Do your process
return processedMessage;
}
}
public void ConfigureServices(IServiceCollection services)
{
...
services.AddSingleton<IKafkaMessageProcessService, KafkaMessageProcessService>();
...
}
Local Build and DEMO
Move the demo folder outside of KafkaSignalR folder.
Open demo\UI.ServiceKafkaConsumerService.csproj project
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. |
-
net9.0
- Confluent.Kafka (>= 2.8.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.