forked from big-data-europe/docker-hadoop
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
48 lines (40 loc) · 1.93 KB
/
Makefile
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
DOCKER_NETWORK = hadoop_network
ENV_FILE = hadoop.env
VERSION = 2.0.0-hadoop3.3.6-java11
build:
docker build -t bde2020/hadoop-base:$(VERSION) ./base
docker build -t bde2020/hadoop-namenode:$(VERSION) ./namenode
docker build -t bde2020/hadoop-datanode:$(VERSION) ./datanode
docker build -t bde2020/hadoop-resourcemanager:$(VERSION) ./resourcemanager
docker build -t bde2020/hadoop-nodemanager:$(VERSION) ./nodemanager
docker build -t bde2020/hadoop-historyserver:$(VERSION) ./historyserver
docker build -t bde2020/hadoop-submit:$(VERSION) ./submit
up:
docker compose up -d
down:
docker compose down
stop:
docker compose stop
delete:
docker compose down -v
shell:
docker run \
--rm -it --name temp_hadoop_shell \
--volume $(PWD)/data:/data \
--network ${DOCKER_NETWORK} \
--env-file ${ENV_FILE} \
bde2020/hadoop-base:$(VERSION) /bin/bash
wordcount:
docker build -t hadoop-wordcount ./submit
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -rm -r /output || true
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -mkdir -p /input/
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -copyFromLocal -f /opt/hadoop-3.3.6/README.txt /input/
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} hadoop-wordcount
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -cat /output/*
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -rm -r /output
docker run --rm --network ${DOCKER_NETWORK} --env-file ${ENV_FILE} bde2020/hadoop-base:$(VERSION) hdfs dfs -rm -r /input
debug:
@printf "Docker network: ${DOCKER_NETWORK}\n"
@printf "Environment file: ${ENV_FILE}\n"
@printf "Hadoop version: ${VERSION}\n"
@printf "Current directory: $(PWD)\n"