Ausführung von README.sh resilienter
[demos/kafka/training] / README.sh
1 #!/bin/bash
2
3 IMAGE=juplo/rest-producer: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-1 kafka-2 kafka-3 cli
13 docker-compose rm -svf producer
14
15 if [[
16   $(docker image ls -q $IMAGE) == "" ||
17   "$1" = "build"
18 ]]
19 then
20   mvn clean install || exit
21 else
22   echo "Using image existing images:"
23   docker image ls $IMAGE
24 fi
25
26 echo "Waiting for the Kafka-Cluster to become ready..."
27 docker-compose exec cli cub kafka-ready -b kafka:9092 1 60 > /dev/null 2>&1 || exit 1
28 docker-compose up setup
29 docker-compose up -d producer-0 producer-1
30 while ! [[ $(http -b :8000/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for producer-0; sleep 1; done
31 while ! [[ $(http -b :8001/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for producer-1; sleep 1; done
32 docker-compose up -d consumer
33
34 echo foo | http -v :8000/foo
35 echo foo | http -v :8001/foo
36 echo foo | http -v :8001/foo
37 echo foo | http -v :8000/bar
38 echo foobar | http -v :8000/bar
39 echo foofoo | http -v :8000/bar
40 echo barbar | http -v :8000/bar
41 echo barfoo | http -v :8000/bar
42 echo bar | http -v :8000/bar
43
44 docker-compose logs consumer
45
46 docker-compose up -d
47 docker-compose exec cli kafkacat -C -b kafka:9092 -t test -o 0 -f'p=%p|o=%o|k=%k|v=%s\n' -q -c20
48
49 docker-compose exec -T cli bash << 'EOF'
50 echo "Altering number of partitions from 3 to 7..."
51 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
52 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
53 kafka-topics --bootstrap-server kafka:9092 --alter --topic test --partitions 7
54 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
55 EOF
56
57 docker-compose restart producer-0 producer-1
58 while ! [[ $(http -b :8000/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8000/actuator/health; sleep 1; done
59 while ! [[ $(http -b :8001/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8001/actuator/health; sleep 1; done
60 docker-compose exec cli kafkacat -C -b kafka:9092 -t test -o 0 -f'p=%p|o=%o|k=%k|v=%s\n' -q -c20
61
62 echo "Messages from peter"
63 docker-compose logs consumer | grep k=peter
64 echo "Messages from beate"
65 docker-compose logs consumer | grep k=beate
66 echo "Messages from foo"
67 docker-compose logs consumer | grep k=foo