/nkafka

.net native kafka library

Primary LanguageC#Apache License 2.0Apache-2.0

Hex.pm

Build

NKafka

It is a high performance fully managed client for Kafka.

Disclaimer

This project is not a port of some existing library. However, some of the solutions used in it have been adapted from other sources. The following libraries acted as such sources:

Quick start

dotnet-nuget install Nkafka

Simple producing message

using NKafka;
using NKafka.Config;

var clusterConfig = new ClusterConfig
{
    BootstrapServers = new[]
    {
        "127.0.0.1:29091"
    },
};

await using var kafkaCluster = await clusterConfig.CreateClusterAsync();

await using var producer = kafkaCluster.BuildProducer<Null, int>();

var testMessage = new Message<Null, int>
{
    Value = 1,
    Partition = new Partition(1)
};

//send message with awaiting
await producer.ProduceAsync("test_topic", testMessage);

//send message as fire and forget
producer.Produce("test_topic", testMessage);

Console.ReadKey();

Simple consumer messages

using NKafka;
using NKafka.Config;

var clusterConfig = new ClusterConfig
{
    BootstrapServers = new[]
    {
        "127.0.0.1:29091"
    },
};

await using var kafkaCluster = await clusterConfig.CreateClusterAsync();

await using var consumer = kafkaCluster.BuildConsumer<Null, int>(new ConsumerConfig
{
    GroupId = "consumer-group"
});

var channel = await consumer.SubscribeAsync("test_topic");

while (await channel.WaitToReadAsync())
{
    var message = await channel.ReadAsync();
    Console.WriteLine(message.Message.Value);
    await consumer.CommitOffsetAsync();
} //Infinite reading of data from a channel
consumer.Unsubscribe();


Console.ReadKey();

Getting started with the repository

1. run git clone https://github.com/kalduzov/nkafka

2. run update_repo.ps1 or update_repo.sh