diff --git a/scripts/Makefile.docker b/scripts/Makefile.docker
new file mode 100644
index 0000000000000000000000000000000000000000..9eadc48d1b4d6dc10f0c183612103b946a7adaf0
--- /dev/null
+++ b/scripts/Makefile.docker
@@ -0,0 +1,48 @@
+# Based on https://netfuture.ch/2020/05/multi-arch-docker-image-easy/
+#
+# Example: make -f Makefile.docker docker-multiarch (TAG=latest)
+
+REGISTRY	= cznic
+BASETAG		= ${REGISTRY}/knot
+PLATFORMS	= linux/amd64,linux/arm/v7,linux/arm64/v8
+
+GITHASH		= $(shell git rev-parse --short HEAD)
+GITBRANCH	= $(shell git rev-parse --abbrev-ref HEAD)
+BRANCHTAG	= $(shell [ -n "${GITBRANCH}" ] && echo "-t ${BASETAG}:${GITBRANCH}" || echo "")
+EXTRATAG	= $(shell [ -n "${TAG}" ] && echo "-t ${BASETAG}:${TAG}" || echo "")
+LABEL		= $(shell [ -n "${GITHASH}" ] && echo "--label knot.git.hash=${GITHASH}" || echo "")
+
+BUILDXDETECT	= ${HOME}/.docker/cli-plugins/docker-buildx
+QEMUDETECT	= /proc/sys/fs/binfmt_misc/qemu-m68k
+
+docker-multiarch: qemu buildx docker-multiarch-builder
+#	docker login
+	docker buildx build --builder docker-multiarch --pull --push ${LABEL} \
+	                    --platform ${PLATFORMS} ${BRANCHTAG} ${EXTRATAG} ..
+
+qemu: ${QEMUDETECT}
+${QEMUDETECT}:
+	docker pull multiarch/qemu-user-static
+	docker run --privileged multiarch/qemu-user-static --reset -p yes
+	docker ps -a | sed -n 's, *multiarch/qemu-user-static.*,,p' \
+	  | (xargs docker rm 2>&1 || \
+	    echo "Cannot remove docker container on ZFS; retry after next reboot") \
+	  | grep -v 'dataset is busy'
+
+buildx: ${BUILDXDETECT}
+${BUILDXDETECT}:
+	@echo
+# Output of `uname -m` is too different
+	@echo '*** `docker buildx` missing. Install binary for this machine architecture'
+	@echo '*** from `https://github.com/docker/buildx/releases/latest`'
+	@echo '*** to `~/.docker/cli-plugins/docker-buildx` and `chmod +x` it.'
+	@echo
+	@exit 1
+
+docker-multiarch-builder: qemu buildx
+	if ! docker buildx ls | grep -w docker-multiarch > /dev/null; then \
+		docker buildx create --name docker-multiarch && \
+		docker buildx inspect --builder docker-multiarch --bootstrap; \
+	fi
+
+.PHONY: qemu buildx docker-multiarch docker-multiarch-builder