1
1
version : ' 3'
2
+
2
3
# Configuration environment variables:
3
4
# - DATAFLOW_VERSION and SKIPPER_VERSION specify what DataFlow and Skipper image versions to use.
4
5
# - STREAM_APPS_URI and TASK_APPS_URI are used to specify what Stream and Task applications to pre-register.
@@ -19,40 +20,94 @@ version: '3'
19
20
# The deployed stream applications that run in their own docker containers (e.g. docker:// registered apps),
20
21
# can be reached on the ports they expose.
21
22
services :
23
+ mariadb :
24
+ image : mariadb:10.4.22
25
+ container_name : dataflow-mariadb
26
+ environment :
27
+ MARIADB_DATABASE : dataflow
28
+ MARIADB_ROOT_PASSWORD : rootpw
29
+ expose :
30
+ - 3306
31
+
32
+ kafka-broker :
33
+ image : confluentinc/cp-kafka:5.5.2
34
+ container_name : dataflow-kafka
35
+ expose :
36
+ - " 9092"
37
+ environment :
38
+ - KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://kafka-broker:9092
39
+ - KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181
40
+ - KAFKA_ADVERTISED_HOST_NAME=kafka-broker
41
+ - KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR=1
42
+ - KAFKA_LOG4J_ROOT_LOGLEVEL=ERROR
43
+ - KAFKA_LOG4J_LOGGERS=org.apache.zookeeper=ERROR,org.apache.kafka=ERROR,kafka=ERROR,kafka.cluster=ERROR,kafka.controller=ERROR,kafka.coordinator=ERROR,kafka.log=ERROR,kafka.server=ERROR,kafka.zookeeper=ERROR,state.change.logger=ERROR
44
+ depends_on :
45
+ - zookeeper
46
+
47
+ zookeeper :
48
+ image : confluentinc/cp-zookeeper:5.5.2
49
+ container_name : dataflow-kafka-zookeeper
50
+ expose :
51
+ - " 2181"
52
+ environment :
53
+ - ZOOKEEPER_CLIENT_PORT=2181
54
+
22
55
dataflow-server :
23
56
user : root
24
- platform : linux/amd64
25
- image : springcloud/spring-cloud-dataflow-server:${DATAFLOW_VERSION:-2.11.0-SNAPSHOT}${BP_JVM_VERSION:-}
57
+ image :
springcloud/spring-cloud-dataflow-server:${DATAFLOW_VERSION:[email protected] @}${BP_JVM_VERSION:-}
26
58
container_name : dataflow-server
27
59
ports :
28
60
- " 9393:9393"
29
61
environment :
30
- - LANG=en_US.utf8
31
- - LC_ALL=en_US.utf8
32
- - JDK_JAVA_OPTIONS=-Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8
62
+ - SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_STREAM_SPRING_CLOUD_STREAM_KAFKA_BINDER_BROKERS=PLAINTEXT://kafka-broker:9092
63
+ - SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_STREAM_SPRING_CLOUD_STREAM_KAFKA_STREAMS_BINDER_BROKERS=PLAINTEXT://kafka-broker:9092
64
+ - SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_STREAM_SPRING_CLOUD_STREAM_KAFKA_BINDER_ZKNODES=zookeeper:2181
65
+ - SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_STREAM_SPRING_CLOUD_STREAM_KAFKA_STREAMS_BINDER_ZKNODES=zookeeper:2181
66
+
67
+ - SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_STREAM_SPRING_KAFKA_STREAMS_PROPERTIES_METRICS_RECORDING_LEVEL=DEBUG
33
68
# Set CLOSECONTEXTENABLED=true to ensure that the CRT launcher is closed.
34
69
- SPRING_CLOUD_DATAFLOW_APPLICATIONPROPERTIES_TASK_SPRING_CLOUD_TASK_CLOSECONTEXTENABLED=true
70
+
35
71
- SPRING_CLOUD_SKIPPER_CLIENT_SERVER_URI=${SKIPPER_URI:-http://skipper-server:7577}/api
72
+
73
+ - SPRING_DATASOURCE_URL=jdbc:mariadb://mariadb:3306/dataflow
74
+ - SPRING_DATASOURCE_USERNAME=root
75
+ - SPRING_DATASOURCE_PASSWORD=rootpw
76
+ - SPRING_DATASOURCE_DRIVER_CLASS_NAME=org.mariadb.jdbc.Driver
36
77
# (Optionally) authenticate the default Docker Hub access for the App Metadata access.
37
78
- SPRING_CLOUD_DATAFLOW_CONTAINER_REGISTRY_CONFIGURATIONS_DEFAULT_USER=${METADATA_DEFAULT_DOCKERHUB_USER}
38
79
- SPRING_CLOUD_DATAFLOW_CONTAINER_REGISTRY_CONFIGURATIONS_DEFAULT_SECRET=${METADATA_DEFAULT_DOCKERHUB_PASSWORD}
80
+
39
81
- SPRING_CLOUD_DATAFLOW_CONTAINER_REGISTRYCONFIGURATIONS_DEFAULT_USER=${METADATA_DEFAULT_DOCKERHUB_USER}
40
82
- SPRING_CLOUD_DATAFLOW_CONTAINER_REGISTRYCONFIGURATIONS_DEFAULT_SECRET=${METADATA_DEFAULT_DOCKERHUB_PASSWORD}
41
83
depends_on :
84
+ - kafka-broker
42
85
- skipper-server
86
+ entrypoint : >
87
+ /bin/sh -c "
88
+ apt-get update && apt-get install --no-install-recommends -y wget &&
89
+ wget --no-check-certificate -P /tmp/ https://raw.githubusercontent.com/vishnubob/wait-for-it/master/wait-for-it.sh &&
90
+ chmod a+x /tmp/wait-for-it.sh &&
91
+ /tmp/wait-for-it.sh mariadb:3306 -- /cnb/process/web"
43
92
restart : always
44
93
volumes :
45
94
- ${HOST_MOUNT_PATH:-.}:${DOCKER_MOUNT_PATH:-/home/cnb/scdf}
46
95
47
96
app-import-stream :
48
- platform : linux/amd64
49
97
image : springcloud/baseimage:1.0.1
50
98
container_name : dataflow-app-import-stream
51
99
depends_on :
52
100
- dataflow-server
101
+ command : >
102
+ /bin/sh -c "
103
+ ./wait-for-it.sh -t 360 dataflow-server:9393;
104
+ wget -qO- '${DATAFLOW_URI:-http://dataflow-server:9393}/apps' --no-check-certificate --post-data='uri=${STREAM_APPS_URI:-https://dataflow.spring.io/kafka-maven-latest&force=true}';
105
+ wget -qO- '${DATAFLOW_URI:-http://dataflow-server:9393}/apps/sink/ver-log/3.0.1' --no-check-certificate --post-data='uri=maven://org.springframework.cloud.stream.app:log-sink-kafka:3.0.1';
106
+ wget -qO- '${DATAFLOW_URI:-http://dataflow-server:9393}/apps/sink/ver-log/2.1.5.RELEASE' --no-check-certificate --post-data='uri=maven://org.springframework.cloud.stream.app:log-sink-kafka:2.1.5.RELEASE';
107
+ wget -qO- '${DATAFLOW_URI:-http://dataflow-server:9393}/apps/sink/dataflow-tasklauncher/${DATAFLOW_VERSION:[email protected] @}' --no-check-certificate --post-data='uri=maven://org.springframework.cloud:spring-cloud-dataflow-tasklauncher-sink-kafka:${DATAFLOW_VERSION:[email protected] @}';
108
+ echo 'Maven Stream apps imported'"
53
109
54
110
app-import-task :
55
- platform : linux/amd64
56
111
image : springcloud/baseimage:1.0.1
57
112
container_name : dataflow-app-import-task
58
113
depends_on :
@@ -65,19 +120,25 @@ services:
65
120
66
121
skipper-server :
67
122
user : root
68
- platform : linux/amd64
69
- image : springcloud/spring-cloud-skipper-server:${SKIPPER_VERSION:-2.11.0-SNAPSHOT}${BP_JVM_VERSION:-}
123
+ image :
springcloud/spring-cloud-skipper-server:${SKIPPER_VERSION:[email protected] @}${BP_JVM_VERSION:-}
70
124
container_name : skipper
71
125
ports :
72
126
- " 7577:7577"
73
127
- ${APPS_PORT_RANGE:-20000-20195:20000-20195}
74
128
environment :
75
- - LANG=en_US.utf8
76
- - LC_ALL=en_US.utf8
77
- - JDK_JAVA_OPTIONS=-Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8
78
129
- SPRING_CLOUD_SKIPPER_SERVER_PLATFORM_LOCAL_ACCOUNTS_DEFAULT_PORTRANGE_LOW=20000
79
130
- SPRING_CLOUD_SKIPPER_SERVER_PLATFORM_LOCAL_ACCOUNTS_DEFAULT_PORTRANGE_HIGH=20190
131
+ - SPRING_DATASOURCE_URL=jdbc:mariadb://mariadb:3306/dataflow
132
+ - SPRING_DATASOURCE_USERNAME=root
133
+ - SPRING_DATASOURCE_PASSWORD=rootpw
134
+ - SPRING_DATASOURCE_DRIVER_CLASS_NAME=org.mariadb.jdbc.Driver
80
135
- LOGGING_LEVEL_ORG_SPRINGFRAMEWORK_CLOUD_SKIPPER_SERVER_DEPLOYER=ERROR
136
+ entrypoint : >
137
+ /bin/sh -c "
138
+ apt-get update && apt-get install --no-install-recommends -y wget &&
139
+ wget --no-check-certificate -P /tmp/ https://raw.githubusercontent.com/vishnubob/wait-for-it/master/wait-for-it.sh &&
140
+ chmod a+x /tmp/wait-for-it.sh &&
141
+ /tmp/wait-for-it.sh mariadb:3306 -- /cnb/process/web"
81
142
restart : always
82
143
volumes :
83
144
- ${HOST_MOUNT_PATH:-.}:${DOCKER_MOUNT_PATH:-/home/cnb/scdf}
0 commit comments