Apache Kafka Channels
Kafka channels are those backed by Apache Kafka
topics.
Deployment steps
-
Setup
Knative Eventing
-
Install an Apache Kafka cluster, if you have not done so already.
For Kubernetes a simple installation is done using the
Strimzi Kafka Operator. Its installation
guides provide content for Kubernetes and
Openshift.
Note: This KafkaChannel
is not limited to Apache Kafka installations on
Kubernetes. It is also possible to use an off-cluster Apache Kafka
installation.
-
Now that Apache Kafka is installed, you need to configure the
bootstrapServers
value in the config-kafka
ConfigMap, located inside the
config/400-kafka-config.yaml
file.
apiVersion: v1
kind: ConfigMap
metadata:
name: config-kafka
namespace: knative-eventing
data:
# Broker URL. Replace this with the URLs for your kafka cluster,
# which is in the format of my-cluster-kafka-bootstrap.my-kafka-namespace:9092.
bootstrapServers: REPLACE_WITH_CLUSTER_URL
-
Apply the Kafka config:
ko apply -f config
-
Create the KafkaChannel
custom objects:
apiVersion: messaging.knative.dev/v1beta1
kind: KafkaChannel
metadata:
name: my-kafka-channel
spec:
numPartitions: 1
replicationFactor: 1
You can configure the number of partitions with numPartitions
, as well as
the replication factor with replicationFactor
. If not set, both will
default to 1
.
Components
The major components are:
- Kafka Channel Controller
- Kafka Channel Dispatcher
- Kafka Webhook
- Kafka Config Map
The Kafka Channel Controller is located in one Pod:
kubectl get deployment -n knative-eventing kafka-ch-controller
The Kafka Channel Dispatcher receives and distributes all events to the
appropriate consumers:
kubectl get deployment -n knative-eventing kafka-ch-dispatcher
The Kafka Webhook is used to validate and set defaults to KafkaChannel
custom
objects:
kubectl get deployment -n knative-eventing kafka-webhook
The Kafka Config Map is used to configure the bootstrapServers
of your Apache
Kafka installation:
kubectl get configmap -n knative-eventing config-kafka
Namespace Dispatchers
By default events are received and dispatched by a single cluster-scoped
dispatcher components. You can also specify whether events should be received
and dispatched by the dispatcher in the same namespace as the channel definition
by adding the eventing.knative.dev/scope: namespace
annotation.
First, you need to create the configMap config-kafka
in the same namespace as
the KafkaChannel.
apiVersion: v1
kind: ConfigMap
metadata:
name: config-kafka
namespace: <YOUR_NAMESPACE>
data:
# Broker URL. Replace this with the URLs for your kafka cluster,
# which is in the format of my-cluster-kafka-bootstrap.my-kafka-namespace:9092.
bootstrapServers: REPLACE_WITH_CLUSTER_URL
Note: the bootstrapServers
value does not have to be the same as the one
specified in knative-eventing/config-kafka
.
Then create a KafkaChannel:
apiVersion: messaging.knative.dev/v1beta1
kind: KafkaChannel
metadata:
name: my-kafka-channel
namespace: <YOUR_NAMESPACE>
annotations:
eventing.knative.dev/scope: namespace
spec:
numPartitions: 1
replicationFactor: 1
The dispatcher is created in <YOUR_NAMESPACE>
:
kubectl get deployment -n <YOUR_NAMESPACE> kafka-ch-dispatcher
Both cluster-scoped and namespace-scoped dispatcher can coexist. However once
the annotation is set (or not set), its value is immutable.
Configuring Kafka client, Sarama
You can configure the Sarama instance used in the KafkaChannel by defining a
sarama
field inside the config-kafka
configmap.
apiVersion: v1
kind: ConfigMap
metadata:
name: config-kafka
namespace: knative-eventing
data:
bootstrapServers: ...
...
sarama: |
Version: 2.0.0 # Kafka Version Compatibility From Sarama's Supported List (Major.Minor.Patch)
Admin:
Timeout: 10000000000 # 10 seconds
Net:
KeepAlive: 30000000000 # 30 seconds
Metadata:
RefreshFrequency: 300000000000 # 5 minutes
Consumer:
Offsets:
AutoCommit:
Interval: 5000000000 # 5 seconds
Retention: 604800000000000 # 1 week
Producer:
Idempotent: true # Must be false for Azure EventHubs
RequiredAcks: -1 # -1 = WaitForAll, Most stringent option for "at-least-once" delivery.
Settings defined here are used as the defaults by the KafkaChannel. The
additional settings defined in the channel CR, such as authentication, are
applied on top of these defaults.
Also, some Sarama settings are required for the channel to work, such as
Consumer.Return.Errors
and Producer.Return.Successes
, so the value for these
in the config-kafka
is ignored.
Value of the sarama
key must be valid YAML string. The string is marshalled
into a
Sarama config struct,
with a few exceptions (Version
and certificates).
To specify a certificate, you can use the following format where you should make
sure to use the YAML string syntax of "|-" in order to prevent trailing
linefeed. The indentation of the PEM content is also important and must be
aligned as shown.
apiVersion: v1
kind: ConfigMap
metadata:
name: config-kafka
namespace: knative-eventing
data:
sarama: |
...
Net:
TLS:
...
Config:
RootCaPems:
- |-
-----BEGIN CERTIFICATE-----
MIIGBDCCA+ygAwIBAgIJAKi1aEV58cQ1MA0GCSqGSIb3DQEBCwUAMIGOMQswCQYD
...
2wk9rLRZaQnhspt6MhlmU0qkaEZpYND3emR2XZ07m51jXqDUgTjXYCSggImUsARs
NAehp9bMeco=
-----END CERTIFICATE-----