Merge der überarbeiteten Compose-Konfiguration ('deserialization')
[demos/kafka/training] / README.sh
1 #!/bin/bash
2
3 IMAGE=juplo/springified-endless-consumer:1.0-SNAPSHOT
4
5 if [ "$1" = "cleanup" ]
6 then
7   docker-compose down -v
8   mvn clean
9   exit
10 fi
11
12 docker-compose up -d zookeeper kafka cli
13
14 if [[
15   $(docker image ls -q $IMAGE) == "" ||
16   "$1" = "build"
17 ]]
18 then
19   mvn install || exit
20 else
21   echo "Using image existing images:"
22   docker image ls $IMAGE
23 fi
24
25 echo "Waiting for the Kafka-Cluster to become ready..."
26 docker-compose exec cli cub kafka-ready -b kafka:9092 1 60 > /dev/null 2>&1 || exit 1
27 docker-compose up setup
28 docker-compose up -d producer consumer
29 until [[ $(http 0:8080/actuator/health 2> /dev/null) =~ "UP" ]]; do echo "Waiting for the producer..."; sleep 1; done
30 echo 'Hallo Welt!' | http -v :8080/peter
31 echo peter | http -v :8080/
32 http -v PUT :8080/peter
33 docker-compose exec -T cli bash << 'EOF'
34 echo "Writing poison pill into topic test..."
35 # tag::poisonpill[]
36 echo 'BOOM!' | kafkacat -P -b kafka:9092 -t test
37 # end::poisonpill[]
38 EOF
39 until [[ $(http 0:8081/actuator/health 2> /dev/null) =~ "UP" ]]; do echo "Waiting for the consumer..."; sleep 1; done
40 sleep 5
41 http -v :8081/seen
42 http -v :8081/actuator/health
43 docker-compose stop producer consumer
44 docker-compose ps
45 docker-compose logs consumer
46 docker-compose exec -T cli bash << 'EOF'
47 echo "Messages in topic \"test\":"
48 kafkacat -C -b kafka:9092 -t test -o 0 -e
49 echo "Messages in topic \"dlq\":"
50 kafkacat -C -b kafka:9092 -t dlq -o 0 -e
51 EOF