Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/invadergir/kafka-streams-scala-template
Template starter project for kafka-streams with scala, including unit tests, configuration, and fat jar support.
https://github.com/invadergir/kafka-streams-scala-template
kafka-streams scala template
Last synced: 2 months ago
JSON representation
Template starter project for kafka-streams with scala, including unit tests, configuration, and fat jar support.
- Host: GitHub
- URL: https://github.com/invadergir/kafka-streams-scala-template
- Owner: invadergir
- License: apache-2.0
- Created: 2018-07-18T23:03:15.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-07-21T21:53:47.000Z (over 2 years ago)
- Last Synced: 2024-06-22T08:53:55.871Z (7 months ago)
- Topics: kafka-streams, scala, template
- Language: Scala
- Size: 35.2 KB
- Stars: 3
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Template / Starter App for Kafka Streams
## Goals
To provide a starter project for Kafka Streams with Scala. It includes:
* Simple working stream processor with both Scala-style and Java-style flatMap examples, ready to be added to.
* Logging with scala-logging
* unit-testing of streams via mockedstreams
* Json handling with Json4s
* Fat jar support via assembly plugin## To Use
### Run
If you run this project, the example behavior is to transform the input messages on the "input" topic in the following way:
1. Copy input message into two
1. The first copy is unchanged.
1. The 2nd copy is modified. For messages that parse into JSON, add "X": "XXX" to it. For non-JSON, simply append "XXX" to the end.The transformed messages are output onto the "output" topic.
This project also can be used to test robot framework kafka stream testing applications. See [https://github.com/invadergir/robotframework-pykafka](https://github.com/invadergir/robotframework-pykafka) for an example for testing this app in robot framework.
To build and run the project (must have [sbt](https://www.scala-sbt.org/download.html) installed):
```
sbt test run
```Use your favorite kafka producer and consumer to send it text strings and/or JSON strings to see what it does on the output topic. For example:
```
kafka-console-producer.sh --broker-list localhost:9092 --property parse.key=true --property 'key.separator=~~' --property key.deserializer=org.apache.kafka.common.serialization.StringDeserializer --topic input
>A~~1
>B~~2
```The output should be:
```
+ kafka-console-consumer.sh --bootstrap-server localhost:9092 --formatter kafka.tools.DefaultMessageFormatter --property print.key=true --property print.value=true --property key.deserializer=org.apache.kafka.common.serialization.StringDeserializer --property value.deserializer=org.apache.kafka.common.serialization.StringDeserializer --topic output
A 1
A 1XXX
B 2
B 2XXX
```### Build Jar
```
sbt assembly
```### To Rename Project
To use this as a starter project, you can run the 'renameproject.sh' script as follows:
```
./renameproject.sh new-project-name -p $NEW_PACKAGE_PREFIX
```
...where NEW_PACKAGE_PREFIX is "com.mycompany.myproject" or something like that.For help running the script, please type:
```
./renameproject.sh -h
```