Pulsar C# client

    You can install the Pulsar C# client library either through the dotnet CLI or through the Visual Studio. This section describes how to install the Pulsar C# client library through the dotnet CLI. For information about how to install the Pulsar C# client library through the Visual Studio, see here.

    Install the , which provides the dotnet command-line tool. Starting in Visual Studio 2017, the dotnet CLI is automatically installed with any .NET Core related workloads.

    Procedures

    To install the Pulsar C# client library, following these steps:

    1. Create a project.

      1. Create a folder for the project.

      2. Open a terminal window and switch to the new folder.

      3. Create the project using the following command.

    1. Add the DotPulsar NuGet package.

      1. Use the following command to install the DotPulsar package.

        1. dotnet add package DotPulsar
    1. 2. After the command completes, open the `.csproj` file to see the added reference.
    2. ```
    3. <ItemGroup>
    4. <PackageReference Include="DotPulsar" Version="2.0.1" />
    5. </ItemGroup>
    6. ```

    Client

    This section describes some configuration examples for the Pulsar C# client.

    Create client

    This example shows how to create a Pulsar C# client connected to localhost.

    1. using DotPulsar;
    2. var client = PulsarClient.Builder().Build();

    To create a Pulsar C# client by using the builder, you can specify the following options.

    Create producer

    This section describes how to create a producer.

    • Create a producer by using the builder.

      1. using DotPulsar;
      2. using DotPulsar.Extensions;
      3. var producer = client.NewProducer())
      4. .Topic("persistent://public/default/mytopic")
      5. .Create();
    • Create a producer without using the builder.

      1. using DotPulsar;
      2. var options = new ProducerOptions<byte[]>("persistent://public/default/mytopic", Schema.ByteArray);
      3. var producer = client.CreateProducer(options);

    Create consumer

    • Create a consumer by using the builder.

      1. using DotPulsar.Extensions;
      2. var consumer = client.NewConsumer()
      3. .SubscriptionName("MySubscription")
      4. .Topic("persistent://public/default/mytopic")
      5. .Create();
    • Create a consumer without using the builder.

    This section describes how to create a reader.

    • Create a reader by using the builder.

      1. using DotPulsar;
      2. using DotPulsar.Extensions;
      3. var reader = client.NewReader()
      4. .StartMessageId(MessageId.Earliest)
      5. .Topic("persistent://public/default/mytopic")
      6. .Create();
    • Create a reader without using the builder.

      1. using DotPulsar;
      2. var options = new ReaderOptions<byte[]>(MessageId.Earliest, "persistent://public/default/mytopic", Schema.ByteArray);

    Configure encryption policies

    The Pulsar C# client supports four kinds of encryption policies:

    • EnforceUnencrypted: always use unencrypted connections.
    • EnforceEncrypted: always use encrypted connections)
    • PreferUnencrypted: use unencrypted connections, if possible.
    • PreferEncrypted: use encrypted connections, if possible.

    This example shows how to set the EnforceUnencrypted encryption policy.

    1. using DotPulsar;
    2. var client = PulsarClient.Builder()
    3. .ConnectionSecurity(EncryptionPolicy.EnforceEncrypted)
    4. .Build();

    Configure authentication

    Currently, the Pulsar C# client supports the TLS (Transport Layer Security) and JWT (JSON Web Token) authentication.

    If you have followed , you get a certificate and a key. To use them from the Pulsar C# client, follow these steps:

    1. Create an unencrypted and password-less pfx file.

      1. openssl pkcs12 -export -keypbe NONE -certpbe NONE -out admin.pfx -inkey admin.key.pem -in admin.cert.pem -passout pass:
    1. Use the admin.pfx file to create an X509Certificate2 and pass it to the Pulsar C# client.

      1. using System.Security.Cryptography.X509Certificates;
      2. using DotPulsar;
      3. var clientCertificate = new X509Certificate2("admin.pfx");
      4. var client = PulsarClient.Builder()
      5. .AuthenticateUsingClientCertificate(clientCertificate)
      6. .Build();

    A producer is a process that attaches to a topic and publishes messages to a Pulsar broker for processing. This section describes some configuration examples about the producer.

    Send data

    This example shows how to send data.

    1. var data = Encoding.UTF8.GetBytes("Hello World");
    2. await producer.Send(data);

    Send messages with customized metadata

    • Send messages with customized metadata by using the builder.

      1. var messageId = await producer.NewMessage()
      2. .Property("SomeKey", "SomeValue")
      3. .Send(data);
    • Send messages with customized metadata without using the builder.

    Receive messages

    This example shows how a consumer receives messages from a topic.

    1. await foreach (var message in consumer.Messages())
    2. {
    3. Console.WriteLine("Received: " + Encoding.UTF8.GetString(message.Data.ToArray()));
    4. }

    Messages can be acknowledged individually or cumulatively. For details about message acknowledgement, see .

    • Acknowledge messages individually.

      1. await consumer.Acknowledge(message);

    Unsubscribe from topics

    This example shows how a consumer unsubscribes from a topic.

    1. await consumer.Unsubscribe();

    Note

    Reader

    A reader is actually just a consumer without a cursor. This means that Pulsar does not keep track of your progress and there is no need to acknowledge messages.

    This example shows how a reader receives messages.

    1. await foreach (var message in reader.Messages())
    2. {
    3. Console.WriteLine("Received: " + Encoding.UTF8.GetString(message.Data.ToArray()));
    4. }

    This section describes how to monitor the producer, consumer, and reader state.

    Monitor producer

    The following table lists states available for the producer.

    This example shows how to monitor the producer state.

    1. private static async ValueTask Monitor(IProducer producer, CancellationToken cancellationToken)
    2. {
    3. var state = ProducerState.Disconnected;
    4. while (!cancellationToken.IsCancellationRequested)
    5. {
    6. state = (await producer.StateChangedFrom(state, cancellationToken)).ProducerState;
    7. var stateMessage = state switch
    8. {
    9. ProducerState.Connected => $"The producer is connected",
    10. ProducerState.Disconnected => $"The producer is disconnected",
    11. ProducerState.Closed => $"The producer has closed",
    12. ProducerState.Faulted => $"The producer has faulted",
    13. ProducerState.PartiallyConnected => $"The producer is partially connected.",
    14. _ => $"The producer has an unknown state '{state}'"
    15. };
    16. Console.WriteLine(stateMessage);
    17. if (producer.IsFinalState(state))
    18. return;
    19. }
    20. }

    Monitor consumer state

    The following table lists states available for the consumer.

    This example shows how to monitor the consumer state.

    1. private static async ValueTask Monitor(IConsumer consumer, CancellationToken cancellationToken)
    2. {
    3. var state = ConsumerState.Disconnected;
    4. while (!cancellationToken.IsCancellationRequested)
    5. {
    6. state = (await consumer.StateChangedFrom(state, cancellationToken)).ConsumerState;
    7. var stateMessage = state switch
    8. {
    9. ConsumerState.Active => "The consumer is active",
    10. ConsumerState.Inactive => "The consumer is inactive",
    11. ConsumerState.Disconnected => "The consumer is disconnected",
    12. ConsumerState.Closed => "The consumer has closed",
    13. ConsumerState.ReachedEndOfTopic => "The consumer has reached end of topic",
    14. ConsumerState.Faulted => "The consumer has faulted",
    15. ConsumerState.Unsubscribed => "The consumer is unsubscribed.",
    16. _ => $"The consumer has an unknown state '{state}'"
    17. };
    18. Console.WriteLine(stateMessage);
    19. if (consumer.IsFinalState(state))
    20. return;
    21. }
    22. }

    Monitor reader state

    The following table lists states available for the reader.

    This example shows how to monitor the reader state.