DEPRICATED: Ersetzt durch 'customized'
[demos/kafka/training] / README.sh
1 #!/bin/bash
2
3 IMAGE=juplo/manual-partitioning: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 kafka 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
39 sleep 10
40 docker-compose stop producer
41 docker-compose up count-0
42 docker-compose up count-1
43 docker-compose up count-2
44
45 docker-compose exec -T cli bash << 'EOF'
46 echo "Altering number of partitions from 3 to 5..."
47 # tag::altertopic[]
48 kafka-topics --bootstrap-server kafka:9092 --alter --topic test --partitions 5
49 kafka-topics --bootstrap-server kafka:9092 --describe --topic test
50 # end::altertopic[]
51 EOF
52
53 docker-compose up -d producer
54 sleep 10
55 docker-compose stop producer
56 docker-compose up count-0
57 docker-compose up count-1
58 docker-compose up count-2
59 docker-compose up count-3
60 docker-compose up count-4
61
62 docker-compose stop producer