Compose-Setup überarbeitet: Grundlage für Übung `simple-consumer-scaling`
[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 consumer-1
30
31 while ! [[ $(http 0:8080/actuator/health 2> /dev/null) =~ "UP" ]]; do echo "Waiting for producer..."; sleep 1; done
32
33 echo foo | http -v :8080/bar
34 echo bar | http -v :8080/foo
35 echo foobar | http -v :8080/bar
36 dd if=/dev/zero bs=1024 count=1024  | http -v :8080/bar
37 echo foofoo | http -v :8080/bar
38 echo barbar | http -v :8080/foo
39 echo foofoo | http -v :8080/bar
40 echo barbar | http -v :8080/foo
41 echo foofoo | http -v :8080/bar
42 echo barbar | http -v :8080/foo
43 echo foofoo | http -v :8080/bar
44 echo barbar | http -v :8080/foo
45 echo foofoo | http -v :8080/bar
46 echo barbar | http -v :8080/foo
47 echo foofoo | http -v :8080/bar
48 echo barbar | http -v :8080/foo
49 echo foofoo | http -v :8080/bar
50 echo barbar | http -v :8080/foo
51 echo foofoo | http -v :8080/bar
52 echo barbar | http -v :8080/foo
53 echo foofoo | http -v :8080/bar
54 echo barbar | http -v :8080/foo
55 echo foofoo | http -v :8080/bar
56 echo barbar | http -v :8080/foo
57 echo foofoo | http -v :8080/bar
58 echo barbar | http -v :8080/foo
59 echo foofoo | http -v :8080/bar
60 echo barbar | http -v :8080/foo
61
62 docker-compose logs producer
63 docker-compose logs consumer-1