forked from ziguicxd/docker-ubuntu-novnc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
113 lines (98 loc) · 3.74 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
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
101
102
103
104
105
106
107
108
109
110
111
112
.PHONY: build manifest buildfat check run debug push save clean clobber
# Default values for variables
REPO ?= fredblgr/
NAME ?= ubuntu-novnc
TAG ?= 20.04
ARCH := $$(arch=$$(uname -m); if [[ $$arch == "x86_64" ]]; then echo amd64; else echo $$arch; fi)
RESOL = 1440x900
ARCHS = amd64 arm64
IMAGES := $(ARCHS:%=$(REPO)$(NAME):$(TAG)-%)
PLATFORMS := $$(first="True"; for a in $(ARCHS); do if [[ $$first == "True" ]]; then printf "linux/%s" $$a; first="False"; else printf ",linux/%s" $$a; fi; done)
# These files will be generated from teh Jinja templates (.j2 sources)
templates = Dockerfile rootfs/etc/supervisor/conf.d/supervisord.conf
# Rebuild the container image and remove intermediary images
build: $(templates)
docker build --tag $(REPO)$(NAME):$(TAG)-$(ARCH) .
@danglingimages=$$(docker images --filter "dangling=true" -q); \
if [[ $$danglingimages != "" ]]; then \
docker rmi $$(docker images --filter "dangling=true" -q); \
fi
# Safe way to build multiarchitecture images:
# - build each image on the matching hardware, with the -$(ARCH) tag
# - push the architecture specific images to Dockerhub
# - build a manifest list referencing those images
# - push the manifest list so that the multiarchitecture image exist
manifest:
docker manifest create $(REPO)$(NAME):$(TAG) $(IMAGES)
@for arch in $(ARCHS); \
do \
echo docker manifest annotate --os linux --arch $$arch $(REPO)$(NAME):$(TAG) $(REPO)$(NAME):$(TAG)-$$arch; \
docker manifest annotate --os linux --arch $$arch $(REPO)$(NAME):$(TAG) $(REPO)$(NAME):$(TAG)-$$arch; \
done
docker manifest push $(REPO)$(NAME):$(TAG)
rmmanifest:
docker manifest rm $(REPO)$(NAME):$(TAG)
# Hasardous way to build multiarchitecture images:
# - use buildx to try to build the different images using qemu for foreign architectures
# This fails with some images because of the emulation of foreign architectures
buildfat:
docker buildx build --push \
--platform $(PLATFORMS) \
--tag $(REPO)$(NAME):$(TAG) .
@danglingimages=$$(docker images --filter "dangling=true" -q); \
if [[ $$danglingimages != "" ]]; then \
docker rmi $$(docker images --filter "dangling=true" -q); \
fi
# Test run the container
# the local dir will be mounted under /src
check:
echo "http://localhost:6080"
docker run --rm \
--publish 6080:80 \
--volume ${PWD}:/workspace:rw \
--env USER=student --env PASSWORD=CS3ASL \
--env "RESOLUTION=$(RESOL)" \
--name $(NAME)-test \
$(REPO)$(NAME):$(TAG)-$(ARCH)
run:
echo "http://localhost:6080"
docker run --rm --detach \
--publish 6080:80 \
--volume "${PWD}":/workspace:rw \
--env USERNAME=`id -n -u` --env USERID=`id -u` \
--env "RESOLUTION=$(RESOL)" \
--name $(NAME)-test \
$(REPO)$(NAME):$(TAG)-$(ARCH)
sleep 5
open http://localhost:6080 || xdg-open http://localhost:6080 || echo "http://localhost:6080"
runasroot:
echo "http://localhost:6080"
docker run --rm --detach \
--publish 6080:80 \
--volume "${PWD}":/workspace:rw \
--env "RESOLUTION=$(RESOL)" \
--name $(NAME)-test \
$(REPO)$(NAME):$(TAG)-$(ARCH)
sleep 5
open http://localhost:6080 || xdg-open http://localhost:6080 || echo "http://localhost:6080"
debug:
echo "http://localhost:6080"
docker run --rm --tty --interactive \
--publish 6080:80 \
--volume "${PWD}":/workspace:rw \
--env USERNAME=`id -n -u` --env USERID=`id -u` \
--env "RESOLUTION=$(RESOL)" \
--name $(NAME)-test \
--entrypoint "bash" \
$(REPO)$(NAME):$(TAG)-$(ARCH)
# Add option -e HTTP_PASSWORD=CS3ASL to control the access to the web page.
# -p 6081:443
push:
docker push $(REPO)$(NAME):$(TAG)-$(ARCH)
save:
docker save $(REPO)$(NAME):$(TAG)-$(ARCH) | gzip > $(NAME)-$(TAG)-$(ARCH).tar.gz
clean:
docker image prune -f
clobber:
docker rmi $(REPO)$(NAME):$(TAG) $(REPO)$(NAME):$(TAG)-$(ARCH)
docker builder prune --all