Skip to content

Latest commit

 

History

History
78 lines (54 loc) · 2.21 KB

File metadata and controls

78 lines (54 loc) · 2.21 KB

AWS Kinesis Source connector

asciinema

Objective

Quickly test Kinesis Connector connector.

AWS Setup

This project assumes ~/.aws/credentials is set, see docker-compose.ymlfile for connect:

    connect:
    <snip>
    volumes:
        - $HOME/.aws/credentials:/root/.aws/credentials:ro

How to run

Simply run:

$ ./kinesis.sh

Details of what the script is doing

Create a Kinesis stream my_kinesis_stream in us-east-1 region as it is default:

$ aws kinesis create-stream --stream-name my_kinesis_stream --shard-count 1

Insert records in Kinesis stream:

$ aws kinesis put-record --stream-name my_kinesis_stream --partition-key 123 --data test-message-1

The connector is created with:

curl -X PUT \
     -H "Content-Type: application/json" \
     --data '{
        "connector.class":"io.confluent.connect.kinesis.KinesisSourceConnector",
               "tasks.max": "1",
               "kafka.topic": "kinesis_topic",
               "kinesis.region": "US_EAST_1",
               "kinesis.stream": "my_kinesis_stream",
               "confluent.license": "",
               "name": "kinesis-source",
               "confluent.topic.bootstrap.servers": "broker:9092",
               "confluent.topic.replication.factor": "1"
          }' \
     http://localhost:8083/connectors/kinesis-source/config | jq .

Verify we have received the data in kinesis_topic topic:

$ docker exec broker kafka-console-consumer --bootstrap-server broker:9092 --topic kinesis_topic --from-beginning --max-messages 1

Delete your stream and clean up resources to avoid incurring any unintended charges:

aws kinesis delete-stream --stream-name my_kinesis_stream

N.B: Control Center is reachable at http://127.0.0.1:9021