Kafka Receiver

Apache Kafka is an open-source distributed event-streaming data platform. The Kafka Receiver enables a STEP platform integrated with Apache Kafka to use a Kafka queue. For more information about Apache Kafka, search the web.

Prerequisites

  1. Before setting up Kafka Receiver, read the Considerations for Setting up Kafka Receiver or Delivery (here) topic in this documentation.
  2. Prior to configuration, clicking the Server dropdown parameter displays the required server name. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive Kafka.Server configuration property. If connecting to a cluster, use a comma-separated list.

    The following example shows two Kafka server configurations where the first server is a cluster:

    Kafka.Server.1=mybroker1a:9092,mybroker1b:9092
    Kafka.Server.2=mybroker2a:9094
  3. Prior to configuration, clicking the Topic dropdown parameter displays the available topics. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive Kafka.Topic configuration property. For example:

    Kafka.Topic.1=my-topic
  4. OPTIONAL: Prior to configuration, clicking the Group Id dropdown parameter displays the available group IDs. Use this setting if you want to overwrite the auto-generated group ID. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive Kafka.GroupId configuration property. For example:

    Kafka.GroupId.1=my-group-id
  5. Prior to configuration, clicking the Keystore Location dropdown parameter displays the required property name. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive Kafka.SSLKeyStoreLocation property. For example:

    Kafka.SSLKeyStoreLocation.1=[/[path]/key_store.jks].
  6. Prior to configuration, clicking the Truststore Location dropdown parameter displays the required property name. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive Kafka.SSLTrustStoreLocation property. For example:

     Kafka.SSLTrustStoreLocation.1=[/[path]/trust_store.jks].
  7. SASL / OAuth 2.0 can be configured for STEP with Kafka using the ExtraDriverOptions property to authenticate securely via bearer tokens. A business function allows integration with the Kafka Receiver by handling the OAuth authentication and returning a HashMap containing the Bearer Token and other details.

    Configure the following case-sensitive sharedconfig.properties entries within the value of the ExtraDriverOptions as shown in the example below, which can be copied:

    • Kafka.Receiver.[IIEP_ID].ExtraDriverOptions - indicate the IIEP ID.

    • stibo.authentication.function - set the JavaScript business function ID. Refer to the Business Function Example for Generating an OAuth Bearer Token section in the Kafka Delivery Method topic here.

    • security.protocol - indicate either SASL_PLAINTEXT (while testing) or SASL_SSL (in production) for the SSL transport layer.

    For example, in the property definition below, ‘MyInboundKafka’ is the ID of the IIEP, ‘HydraAuthFunction’ is the ID of the business function, and ‘SASL_PLAINTEXT’ is the testing value for the security protocol and the rest of the property values are configured as displayed:

    Copy
    Kafka.Receiver.MyInboundKafka.ExtraDriverOptions=sasl.mechanism=OAUTHBEARER,sasl.jaas.config=org.apache.kafka.common.security.oauthbearer.OAuthBearerLoginModule required;,sasl.login.callback.handler.class=com.stibo.integration.kafka.domain.impl.auth.OAuthFunctionCallbackHandler,stibo.authentication.function=HydraAuthFunction,security.protocol=SASL_PLAINTEXT    

Configuration

While STEPXML is recommended for the messaging format, other formats supported for integration with STEP are allowed. The descriptions below have been written for STEPXML.

The Kafka Receiver option is available in an inbound integration endpoint (IIEP).

  1. For the Receiver, choose Kafka Receiver.

  2. For the Server, select the server(s) where the Kafka broker instances used by the endpoint are running.

  3. In Topic, select the topic used by this endpoint.

  4. In Group Id, select the ID to be used to overwrite the auto-generated group ID.

  5. For Use Kafka to Manage Offset, set to 'Yes' to use the Kafka offset management mechanism instead of the STEP-owned one. This makes it easy to know when Kafka can purge messages. For more information, refer to Kafka Topic Offset on the web.

    Set to 'No' (the default) to have the offset managed completely in STEP with no commits done to Kafka.

    Important: When switching from having STEP manage the offset to having Kafka do it, upon invoking the IIEP, all messages that Kafka has available for a given topic will be re-fetched. To prevent this, you can manually tell the Kafka side what the offset should be for your 'consumer group.' The offset is managed individually for each consumer group, and each Kafka IIEP in STEP is its own consumer group.

    Use the kafka-consumer-groups.sh script to list the Kafka consumer groups and identify the one that has the name of your STEP system and the ID of your integration endpoint in its ID. Use the same script and the ID of the consumer group for your STEP IIEP to set the desired offset for your consumer group (this can only be done after the STEP IIEP has been deactivated for at least 15 minutes).

  6. For Max Events To Read Per Poll, enter the maximum number of events to read out of Kafka per invocation.

    Note: Setting this too high can require allocating additional memory in the system.

  1. In Decompress Message Content, optionally select a decompression option:

    • None - message content will remain compressed.
    • LZ4 - lossless data compression algorithm. Search the web for more information.
  2. In Keystore Location, if SSL encryption is required, select an SSL encrypted connection to Kafka. Otherwise, leave this parameter blank.

  3. In Keystore Password, enter the password for keystore if required.

  4. In Keystore PrivateKey Password, enter the password of the private key in the keystore file, if needed.

  5. In Truststore Location, if SSL encryption is required, select an SSL encrypted connection to the Kafka. Otherwise, leave this parameter blank.

  6. In Truststore Password, enter the password for truststore if required.

  7. In Topic Offset, disable the IIEP to edit the value. The Kafka offset tracks the sequential order that messages are received by Kafka topics. Enter the offset from which STEP should read messages.

    Note: When 'Use Kafka to Manage Offset' is set to 'Yes' as described in step 5 above, the Topic Offset parameter is not applicable and removed from the dialog. This is because commits happen after background processes are started for polled messages, and as these messages are consumed, STEP communicates to Kafka that the message has been consumed. Kafka then increments the offset.

  8. Click the Next button to continue with the IIEP - Configure Endpoint step (here), or the Finish button to close the wizard.

Execution Report

The Kafka Receiver execution report includes the following entries:

  • When the Kafka broker is running but no messages are retrieved, the number of events, the Topic, and the Topic Offset are reported.

  • When the Kafka broker is not running, the IIEP fails, and a minimum number of entries are reported since no messages are being processed.