Der Rest-Producer schreibt in eine fixe Partition, wenn so konfiguriert
[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 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 -d kafka-ui
28
29 docker-compose exec -T cli bash << 'EOF'
30 echo "Creating topic with 3 partitions..."
31 kafka-topics --bootstrap-server kafka:9092 --delete --if-exists --topic test
32 # tag::createtopic[]
33 kafka-topics --bootstrap-server kafka:9092 --create --topic test --partitions 3
34 # end::createtopic[]
35 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
36 EOF
37
38 docker-compose up -d producer-0 producer-1 consumer
39
40 while ! [[ $(http -b :8000/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8000/actuator/health; sleep 1; done
41 while ! [[ $(http -b :8001/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8001/actuator/health; sleep 1; done
42 while ! [[ $(http -b :8081/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8081/actuator/health; sleep 1; done
43
44 echo foo | http -v :8000/foo
45 echo foo | http -v :8001/foo
46
47 sleep 5
48
49 http -v :8081/seen
50
51 docker-compose up -d
52
53 sleep 5
54
55 http -v :8081/seen
56 sleep 1
57 http -v :8081/seen
58 sleep 1
59 http -v :8081/seen
60 sleep 1
61 http -v :8081/seen
62 sleep 1
63 http -v :8081/seen
64 sleep 1
65 http -v :8081/seen
66 sleep 1
67 http -v :8081/seen
68 sleep 1
69 http -v :8081/seen
70 sleep 1
71 http -v :8081/seen
72 sleep 1
73 http -v :8081/seen
74
75 docker-compose exec -T cli bash << 'EOF'
76 echo "Altering number of partitions from 3 to 7..."
77 kafka-topics --bootstrap-server kafka:9092 --alter --topic test --partitions 7
78 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
79 EOF
80
81 docker-compose restart producer-0 producer-1
82
83 while ! [[ $(http -b :8000/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8000/actuator/health; sleep 1; done
84 while ! [[ $(http -b :8001/actuator/health | jq -r .status) =~ "UP" ]]; do echo Waiting for :8001/actuator/health; sleep 1; done
85
86 http -v :8081/seen
87 sleep 1
88 http -v :8081/seen
89 sleep 1
90 http -v :8081/seen
91 sleep 1
92 http -v :8081/seen
93 sleep 1
94 http -v :8081/seen
95 sleep 1
96 http -v :8081/seen
97 sleep 1
98 http -v :8081/seen
99 sleep 1
100 http -v :8081/seen
101 sleep 1
102 http -v :8081/seen
103 sleep 1
104 http -v :8081/seen
105
106 docker-compose stop