Skip to content

Go library providing bindings for the Kafka connect API

License

Notifications You must be signed in to change notification settings

reifyhealth/go-kafka-connect

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

go-kafka-connect

Go project containing two different sub-projects: a kafka-connect client library and a CLI to use it.

Kafka-connect client library

This library is to be used as an abstraction layer for the kafka-connect REST API. It currently implements the following API calls:

  • Create a connector
  • Update a connector
  • Delete a connector
  • Pause a connector
  • Resume a connector
  • Restart a connector
  • Get a connector's details (overview, configuration, status or tasks list)

It also contains two 'bonus' features:

  • Do synchronously: All calls to the REST API trigger an asynchronous function on kafka-connect. This feature lets the library check regularly if the action has taken effect on kafka-connect's side, and considers the request as completed only when the consequences of the command can be verified. It allows users of this library to use its functions in a synchronous way.
  • Deploy connector, a function used to deploy a connector, or replace an existing one gracefully. This function checks if the target connector exists. If it exists, it will then be paused before being updated. Before being updating it check the current config. If it match the deployment's config, nothing will be done. The new connector is then deployed, and resumed. This function is always synchronous.

Running

download binary for your system:

  • linux: wget https://github.com/ricardo-ch/go-kafka-connect/releases/download/1.0.0/kccli
  • windows: wget https://github.com/ricardo-ch/go-kafka-connect/releases/download/1.0.0/kccli.exe
  • mac: wget https://github.com/ricardo-ch/go-kafka-connect/releases/download/1.0.0/kccli_mac

set executable if needed chmod +x kccli

enjoy!

Example of command

  • Get help
./kccli --help
  • Deploy a connector which config is stored in a json:
./kccli deploy -u http://kafka-connect.local -f my-connector-config.json
  • Deploy a bunch of connector in parallel and wait for the end:
jobs=''

./kccli deploy -u http://kafka-connect.local -f my-connector-config.json & jobs="$jobs $!"
./kccli deploy -u http://kafka-connect.local -f my-connector-2-config.json & jobs="$jobs $!"

status=0
for job in $jobs; do
  wait $job
  if [ $? != '0' ]; then $status=1; fi
done
if [ $status != 0 ]; then exit $status; fi
  • Get connector status
./kccli -u http://kafka-connect.local get --status -n my-connector

Setup environment for development

Required:

  • Go 1.9
  • Docker (for testing purpose only)

run go get -u github.com/ricardo-ch/go-kafka-connect then inside repo run: make install to install dependencies

Testing

For now, only integration test are available. run make test-integration

Right now, integration tests only run locally

note: you may also run make rundep, if you just want to run a kafka-connect cluster in background for manual testing.

About

Go library providing bindings for the Kafka connect API

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 98.2%
  • Makefile 1.8%