21.3. 使用方法
本节介绍如何使用 ceph-sink
。
21.3.1. Knative Sink
您可以通过将 ceph-sink
Kamelet 绑定到 Knative 对象,将 ceph-sink Kamelet 用作 Knative sink。
ceph-sink-binding.yaml
apiVersion: camel.apache.org/v1alpha1 kind: KameletBinding metadata: name: ceph-sink-binding spec: source: ref: kind: Channel apiVersion: messaging.knative.dev/v1 name: mychannel sink: ref: kind: Kamelet apiVersion: camel.apache.org/v1alpha1 name: ceph-sink properties: accessKey: "The Access Key" bucketName: "The Bucket Name" cephUrl: "http://ceph-storage-address.com" secretKey: "The Secret Key" zoneGroup: "The Bucket Zone Group"
21.3.1.1. 前提条件
确保您已将 "红帽集成 - Camel K" 安装到您连接的 OpenShift 集群中。
21.3.1.2. 使用集群 CLI 的步骤
-
将
ceph-sink-binding.yaml
文件保存到本地驱动器中,然后根据需要编辑该文件。 使用以下命令运行 sink:
oc apply -f ceph-sink-binding.yaml
21.3.1.3. 使用 Kamel CLI 的步骤
使用以下命令配置和运行 sink:
kamel bind channel:mychannel ceph-sink -p "sink.accessKey=The Access Key" -p "sink.bucketName=The Bucket Name" -p "sink.cephUrl=http://ceph-storage-address.com" -p "sink.secretKey=The Secret Key" -p "sink.zoneGroup=The Bucket Zone Group"
此命令在集群的当前命名空间中创建 KameletBinding。
21.3.2. Kafka Sink
您可以通过将 ceph-sink
Kamelet 绑定到 Kafka 主题,将 ceph-sink Kamelet 用作 Kafka sink。
ceph-sink-binding.yaml
apiVersion: camel.apache.org/v1alpha1 kind: KameletBinding metadata: name: ceph-sink-binding spec: source: ref: kind: KafkaTopic apiVersion: kafka.strimzi.io/v1beta1 name: my-topic sink: ref: kind: Kamelet apiVersion: camel.apache.org/v1alpha1 name: ceph-sink properties: accessKey: "The Access Key" bucketName: "The Bucket Name" cephUrl: "http://ceph-storage-address.com" secretKey: "The Secret Key" zoneGroup: "The Bucket Zone Group"
21.3.2.1. 先决条件
确保您已在 OpenShift 集群中安装了 AMQ Streams Operator,并在当前命名空间中创建一个名为 my-topic
的主题。另外,请确保已将 "红帽集成 - Camel K" 安装到您连接的 OpenShift 集群中。
21.3.2.2. 使用集群 CLI 的步骤
-
将
ceph-sink-binding.yaml
文件保存到本地驱动器中,然后根据需要编辑该文件。 使用以下命令运行 sink:
oc apply -f ceph-sink-binding.yaml
21.3.2.3. 使用 Kamel CLI 的步骤
使用以下命令配置和运行 sink:
kamel bind kafka.strimzi.io/v1beta1:KafkaTopic:my-topic ceph-sink -p "sink.accessKey=The Access Key" -p "sink.bucketName=The Bucket Name" -p "sink.cephUrl=http://ceph-storage-address.com" -p "sink.secretKey=The Secret Key" -p "sink.zoneGroup=The Bucket Zone Group"
此命令在集群的当前命名空间中创建 KameletBinding。