Verbesserte Tests und Korrekturen gemerged: stored-offsets -> stored-state
[demos/kafka/training] / README.sh
1 #!/bin/bash
2
3 IMAGE=juplo/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 mongo express
13
14 if [[
15   $(docker image ls -q $IMAGE) == "" ||
16   "$1" = "build"
17 ]]
18 then
19   docker-compose rm -svf peter beate
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 -d kafka-ui
29
30 docker-compose exec -T cli bash << 'EOF'
31 echo "Creating topic with 3 partitions..."
32 kafka-topics --bootstrap-server kafka:9092 --delete --if-exists --topic test
33 # tag::createtopic[]
34 kafka-topics --bootstrap-server kafka:9092 --create --topic test --partitions 3
35 # end::createtopic[]
36 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
37 EOF
38
39 docker-compose up -d consumer
40
41 docker-compose up -d producer
42 sleep 10
43 http -v :8081/state
44 sleep 1
45 http -v :8081/state
46 sleep 1
47 http -v :8081/state
48 sleep 1
49 http -v :8081/state
50
51 docker-compose stop producer
52 docker-compose exec -T cli bash << 'EOF'
53 echo "Altering number of partitions from 3 to 7..."
54 # tag::altertopic[]
55 kafka-topics --bootstrap-server kafka:9092 --alter --topic test --partitions 7
56 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
57 # end::altertopic[]
58 EOF
59
60 docker-compose start producer
61 sleep 1
62 http -v :8081/state
63 sleep 1
64 http -v :8081/state
65 sleep 1
66 http -v :8081/state
67 sleep 1
68 http -v :8081/state
69 sleep 1
70 http -v :8081/state
71 sleep 1
72 http -v :8081/state
73 sleep 1
74 http -v :8081/state
75 sleep 1
76 http -v :8081/state
77 sleep 1
78 http -v :8081/state
79 sleep 1
80 http -v :8081/state
81 sleep 1
82 http -v :8081/state
83 sleep 1
84 http -v :8081/state
85 sleep 1
86 http -v :8081/state
87 sleep 1
88 http -v :8081/state
89 docker-compose stop producer consumer