Developer configuration options¶
Broker configuration¶
- You can specify any valid
namefor your broker. Usingdefaultwill create a broker nameddefault. - The
namespacemust be an existing namespace in your cluster. Usingdefaultwill create the broker in thedefaultnamespace.
Event Delivery Options¶
- You can use
dead-letter sinkfor error handling and auditing of undelivered messages. Specify Kubernetes object reference where undelivered messages will be sent usingrefand an optional URI to route undelivered messages usinguri. - You can set the
Backoff policiesto define the delay strategy between retry attempts. It can beexponentialorlinear. - You can set the
Backoff delayto specify the initial delay before retrying, using the ISO 8601 duration format. - You can specify the number of retry attempts before sending the event to the dead-letter sink using the
retryconfiguration. spec.deliveryis used to configure event delivery options. Event delivery options specify what happens to an event that fails to be delivered to an event sink. For more information, see the documentation on Event delivery.
Advanced broker class options¶
When a Broker is created without a specified eventing.knative.dev/broker.class annotation, by default the MTChannelBasedBroker Broker class is used, as specified in the config-br-defaults ConfigMap.
In case you have multiple Broker classes installed in your cluster and want to use a non-default Broker class for a Broker, you can modify the eventing.knative.dev/broker.class annotation and spec.config for the Broker object.
-
Set the
eventing.knative.dev/broker.classannotation. ReplaceMTChannelBasedBrokerin the following example with the class type you want to use. Be aware that the Broker class annoation is immutable and thus can't be updated after the Broker got created: -
Configure the
spec.configwith the details of the ConfigMap that defines the required configuration for the Broker class (e.g. with some Channel configurations in case of theMTChannelBasedBroker):
For further information about configuring a default Broker class cluster wide or on a per namespace basis, check the Administrator configuration options.
Broker configuration example¶
The following is a full example of a Channel based Broker object which shows the possible configuration options that you can modify:
apiVersion: eventing.knative.dev/v1
kind: Broker
metadata:
name: default
namespace: default
annotations:
eventing.knative.dev/broker.class: MTChannelBasedBroker
spec:
config:
apiVersion: v1
kind: ConfigMap
name: config-br-default-channel
namespace: knative-eventing
delivery:
deadLetterSink:
ref:
kind: Service
namespace: example-namespace
name: example-service
apiVersion: v1
uri: example-uri
retry: 5
backoffPolicy: exponential
backoffDelay: "PT1S"