feat(ansible): Ubuntu Jammy VI.
[csit.git] / fdio.infra.pxe / docker-dnsmasq / Dockerfile
1 FROM ubuntu:22.04 as ubuntu_jammy
2
3 LABEL Description="ubuntu intermediate image"
4 LABEL Version="2.0"
5
6 RUN apt update \
7  && apt install -y wget genisoimage syslinux-common \
8  && mkdir -p /var/lib/tftpboot/grub \
9  && mkdir -p /var/lib/tftpboot/casper/ubuntu-jammy-amd64/ \
10  && mkdir -p /var/lib/tftpboot/casper/ubuntu-jammy-arm64/
11
12 ENV ISO_JAMMY_AMD64 https://releases.ubuntu.com/22.04/ubuntu-22.04.1-live-server-amd64.iso
13 ENV ISO_JAMMY_ARM64 https://cdimage.ubuntu.com/releases/22.04/release/ubuntu-22.04.1-live-server-arm64.iso
14 ENV EFI_JAMMY_AMD64 http://archive.ubuntu.com/ubuntu/dists/focal/main/uefi/grub2-amd64/current/grubnetx64.efi.signed
15 ENV EFI_JAMMY_ARM64 http://ports.ubuntu.com/ubuntu-ports/dists/focal/main/uefi/grub2-arm64/current/grubnetaa64.efi.signed
16
17 RUN echo "Preparing Grub EFI Binary" \
18  && wget $EFI_JAMMY_AMD64 -O /var/lib/tftpboot/grub/grubnetx64.efi.signed \
19  && wget $EFI_JAMMY_ARM64 -O /var/lib/tftpboot/grub/grubnetaa64.efi.signed
20
21 RUN echo "Preparing Casper Kernel" \
22  && wget $ISO_JAMMY_AMD64 -O /ubuntu-22.04.1-live-server-amd64.iso \
23  && isoinfo -i /ubuntu-22.04.1-live-server-amd64.iso -x "/CASPER/INITRD.;1" > /var/lib/tftpboot/casper/ubuntu-jammy-amd64/initrd \
24  && isoinfo -i /ubuntu-22.04.1-live-server-amd64.iso -x "/CASPER/VMLINUZ.;1" > /var/lib/tftpboot/casper/ubuntu-jammy-amd64/vmlinuz\
25  && wget $ISO_JAMMY_ARM64 -O /ubuntu-22.04.1-live-server-arm64.iso \
26  && isoinfo -i /ubuntu-22.04.1-live-server-arm64.iso -x "/CASPER/INITRD.;1" > /var/lib/tftpboot/casper/ubuntu-jammy-arm64/initrd \
27  && isoinfo -i /ubuntu-22.04.1-live-server-arm64.iso -x "/CASPER/VMLINUZ.;1" > /var/lib/tftpboot/casper/ubuntu-jammy-arm64/vmlinuz
28
29 FROM alpine
30
31 LABEL Description="dnsmasq service image"
32 LABEL Version="2.0"
33
34 RUN apk add --update --no-cache dnsmasq \
35  && rm -rf /var/cache/apk/*
36
37 # Extract installer from previous image.
38 COPY --from=ubuntu_jammy /var/lib/tftpboot /var/lib/tftpboot
39
40 # Configure PXE.
41 COPY tftpboot/ /var/lib/tftpboot/
42
43 # Configure DNSMASQ.
44 COPY etc/ /etc/
45
46 # Start dnsmasq. It picks up default configuration from /etc/dnsmasq.conf and
47 # /etc/default/dnsmasq plus any command line switch
48 ENTRYPOINT ["sh","-c","dnsmasq","--interface=$E_INT","--listen-address=$E_ADD"]