-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
100 lines (92 loc) · 2.06 KB
/
docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
version: "3"
services:
namenode:
image: bde2020/hadoop-namenode:2.0.0-hadoop3.2.1-java8
container_name: namenode
hostname: namenode
restart: always
ports:
- 9870:9870
- 9000:9000
volumes:
- hadoop_namenode:/hadoop/dfs/name
env_file:
- ./hadoop.env
networks:
- my_other_network
environment:
- CLUSTER_NAME=test
- HDFS_CONF_dfs_blocksize=67108864
platform: linux/amd64
deploy:
resources:
limits:
memory: 2G
datanode:
image: bde2020/hadoop-datanode:2.0.0-hadoop3.2.1-java8
container_name: datanode
hostname: datanode
restart: always
ports:
- 9864:9864
volumes:
- hadoop_datanode:/hadoop/dfs/data
environment:
SERVICE_PRECONDITION: "namenode:9870"
env_file:
- ./hadoop.env
networks:
- my_other_network
platform: linux/amd64
deploy:
resources:
limits:
memory: 4G
spark-master:
build:
context: .
dockerfile: Dockerfile
hostname: spark-master
container_name: spark-master
command: bin/spark-class org.apache.spark.deploy.master.Master
ports:
- 8080:8080
- 7077:7077
environment:
- SPARK_DRIVER_MEMORY=2G
- SPARK_EXECUTOR_MEMORY=2G
depends_on:
- namenode
- datanode
networks:
- my_other_network
deploy:
resources:
limits:
memory: 7G
spark-worker-1:
build:
context: .
dockerfile: Dockerfile
hostname: spark-worker-1
container_name: spark-worker-1
command: bin/spark-class org.apache.spark.deploy.worker.Worker spark://spark-master:7077
depends_on:
- spark-master
ports:
- "0.0.0.0:8081:8081"
networks:
- my_other_network
environment:
SPARK_MODE: worker
SPARK_WORKER_CORES: 2
SPARK_WORKER_MEMORY: 2g
SPARK_MASTER_URL: spark://spark-master:7077
volumes:
hadoop_namenode:
hadoop_datanode:
hadoop_historyserver:
networks:
my_other_network:
driver: bridge
name: my_other_network