As a developer of OpenShift Connectors, you can use the rhoas
command-line interface (CLI) to create and configure connections between OpenShift Streams for Apache Kafka and third-party systems.
You can use a source connector to send data from an external system to Streams for Apache Kafka. You can use a sink connector to send data from Streams for Apache Kafka to an external system.
For the example in this guide, you create a source connector that sends data from a simple data generator to a Kafka topic. You also create a sink connector that sends data from the Kafka topic to an HTTP site.
-
You’ve installed the latest version of the
rhoas
CLI as described in Installing and configuring the OpenShift Application Services CLI. -
You’ve completed the following tasks:
Note: You can find detailed instructions for these tasks in Creating Kafka resources by using the OpenShift Application Services CLI.
-
Create a Kafka instance.
$ rhoas kafka create --name=my-kafka-instance
-
Verify that the Kafka instance is in the Ready state.
$ rhoas context status kafka
-
Create a service account and copy the service account ID and secret. You must use a service account to connect and authenticate your Connectors instances with your Kafka instance.
$ rhoas service-account create --file-format=json --short-description=test-service-account
-
For your Kafka instance, set the permissions for the service account to enable Connectors instances (that are configured with the service account credentials) to produce and consume messages in any topic in the Kafka instance.
$ rhoas kafka acl grant-access --producer --consumer --service-account=<service-acct-id> --topic all --group all
-
Create a Kafka topic named
test-topic
. The Kafka topic stores messages sent by producers (data sources) and makes them available to consumers (data sinks).$ rhoas kafka topic create --name=test-topic
-
A Connectors namespace hosts your Connectors instances.
The namespace that you use depends on your OpenShift Dedicated environment.
- If you’re using the hosted preview environment
-
You must create a preview namespace before you can create Connectors instances. A preview namespace is active for 48 hours.
- If you’re using a Trial cluster in your own OpenShift Dedicated environment
-
The namespace is created when you add the Connectors service to your Trial cluster, as described in Adding the Red Hat OpenShift Connectors add-on to your OpenShift cluster. Your OpenShift Dedicated Trial cluster namespace is active for 60 days.
-
You’re logged in to
rhoas
.$ rhoas login
-
If you’re using a Trial cluster in your own OpenShift Dedicated environment, skip to Step 2.
If you’re using the Connectors evaluation site, create an evaluation namespace.
$ rhoas connector namespace create --name=eval-namespace
-
Verify that your namespace is listed.
$ rhoas connector namespace list
Before you can create a Connectors instance, you must build a configuration file that is based on a supported connector type that is listed in the Connectors catalog.
For this example, you want to create two types of connectors: a data generator (a source connector) and an HTTP sink connector.
You must build a configuration file for each connector type that you want to create. When you build a configuration file, the default file name is connector.json
. Optionally, you can specify a different configuration file name.
-
Your current local directory is the place where you want to save your Connectors configuration files. For example, if you want to save your configuration files in a directory named
my-connectors
, ensure that themy-connectors
directory is your current directory.$ cd my-connectors
-
You’re logged in to
rhoas
. -
For the sink connector example, open the free Webhook.site page in a browser window. The
Webhook.site
page provides a unique URL that you can use for the example HTTP data sink.
-
Decide which type of connector you want to create.
-
View a list of the supported connector types that are available in the Connectors catalog. The default number of connector types listed is set to 10. To see all Connectors types, specify a limit value of 100.
$ rhoas connector type list --limit=100
-
For this example, find the data generator source connector by specifying "Generator" in the
search
flag.$ rhoas connector type list --search=%Generator%
The result is as follows:
{ "name": "Data Generator source", "id": "data_generator_0.1", "description": "A data generator (for development and testing purposes)." }
-
For this example, find the HTTP sink connector by specifying "HTTP" in the
search
flag.$ rhoas connector type list --search=%HTTP%
The first result is the HTTP sink.
{ "name": "HTTP sink", "id": "http_sink_0.1", "description": "Send data to an HTTP endpoint." }
-
-
Build a configuration file for the
data_generator_0.1
connector type. Specifytest-generator
as the Connectors instance name andtest-generator.json
as the configuration file name.$ rhoas connector build --name=test-generator --type=data_generator_0.1 --output-file=test-generator.json
Note: By default, the configuration file is in JSON format. Optionally, you can specify YAML format by adding
-o yaml
to theconnector build
command. -
Answer the prompts for configuration values.
-
For Format, press ENTER to accept the default (
application/octet-stream
). -
For Error handling method, select
stop
. The Connectors instance stops running if it encounters an error. -
For Topic Names, type
test-topic
. -
For Content Type, accept the default.
-
For Message, type
Hello World!
. -
For Period, accept the default (
1000
).
-
-
Build a configuration file for the
http_sink_0.1
connector type and specifytest-http
as the configuration file name.$ rhoas connector build --name=test-http --type=http_sink_0.1 --output-file=test-http.json
-
Answer the prompts for configuration values.
-
For Format, press ENTER to accept the default (
application/octet-stream
). -
For Error handling method, select
stop
. -
For Method, accept the default (
POST
). -
For URL, paste your unique URL that you copied from the Webhook.site page.
-
For Topic Names, type
test-topic
.
-
-
Verify that the configuration files were built.
$ ls
The result shows the
test-generator.json
andtest-http.json
files. -
Optionally, you can edit a configuration file in an editor of your choice.
Note: To prevent saving sensitive data to disk, the values for the service account and the namespace are not included in the configuration file. You’re prompted to specify those values when you create an Connectors instance.
After you build a configuration file based on a connector type, you can use the configuration file to create a Connectors instance.
For this example, you create two Connectors instances: a data generator source Connectors instance and an HTTP sink Connectors instance.
-
You have built configuration files based on each type of connector that you want to create.
-
The configuration files are saved in your current directory.
-
You have a Connectors namespace.
-
You have an OpenShift Streams for Apache Kafka instance running and have a topic called
test-topic
. -
You have a service account created that has read and write access to the Kafka topic, and you know the credentials (ID and secret).
-
Create a source Connectors instance by specifying the source connector’s configuration file. For example, the data generator configuration file is
test-generator.json
.$ rhoas connector create --file=test-generator.json
-
Answer the prompts for details about the Connectors instance.
-
For Set the Connectors namespace, select your namespace from the list. For example, select
eval-namespace
. -
For Service Account Client ID, type or paste your ID.
-
For Service Account Client Secret, type or paste your secret.
A message states "Successfully created the Connectors instance".
-
-
Wait until the status of the Connectors instance is Ready.
To check the status:
$ rhoas connector list
-
Verify that your source Connectors instance is producing messages.
$ rhoas kafka topic consume --name=test-topic --partition=0 --wait
-
Create a sink Connectors instance by specifying the sink connector’s configuration file. For example, the HTTP sink configuration file is
test-http.json
.$ rhoas connector create --file=test-http.json
-
Answer the prompts for details about the Connectors instance.
-
For Set the Connectors namespace, select your namespace from the list. For example, select
eval-namespace
. -
For Service Account Client ID, type or paste your ID.
-
For Service Account Client Secret, type or paste your secret.
A message states "Successfully created the Connectors instance".
-
-
Wait until the status of the Connectors instance is Ready.
To check the status:
$ rhoas connector list
-
Verify that your sink Connectors instance is receiving messages by viewing your Webhook.site page in a web browser.
The following rhoas connector
help commands describe additional rhoas connector
commands that you can use to manage your Connectors instances:
-
rhoas connector namespace -h
for managing Connectors namespaces -
rhoas connector type -h
for viewing the available types of connectors -
rhoas connector list -h`
for listing Connectors instances -
rhoas connector build -h
for building configuration files -
rhoas connector create -h
for creating Connectors instances