|
| 1 | +FROM rust:1.86.0@sha256:300ec56abce8cc9448ddea2172747d048ed902a3090e6b57babb2bf19f754081 AS kms-builder |
| 2 | +COPY ./shared /build |
| 3 | +ARG DSTACK_REV |
| 4 | +WORKDIR /build |
| 5 | +RUN ./pin-packages.sh ./kms-pinned-packages.txt |
| 6 | +RUN apt-get update && \ |
| 7 | + apt-get install -y --no-install-recommends \ |
| 8 | + git \ |
| 9 | + build-essential \ |
| 10 | + musl-tools \ |
| 11 | + libssl-dev \ |
| 12 | + protobuf-compiler \ |
| 13 | + libprotobuf-dev \ |
| 14 | + clang \ |
| 15 | + libclang-dev |
| 16 | +RUN git clone https://github.com/Dstack-TEE/dstack.git && \ |
| 17 | + cd dstack && \ |
| 18 | + git checkout ${DSTACK_REV} |
| 19 | +RUN rustup target add x86_64-unknown-linux-musl |
| 20 | +RUN cd dstack && cargo build --release -p dstack-kms --target x86_64-unknown-linux-musl |
| 21 | + |
| 22 | +FROM debian:bookworm@sha256:0d8498a0e9e6a60011df39aab78534cfe940785e7c59d19dfae1eb53ea59babe |
| 23 | +COPY ./shared /build |
| 24 | +WORKDIR /build |
| 25 | +ARG QEMU_REV=d98440811192c08eafc07c7af110593c6b3758ff |
| 26 | +RUN ./pin-packages.sh ./qemu-pinned-packages.txt && \ |
| 27 | + apt-get update && \ |
| 28 | + apt-get install -y --no-install-recommends \ |
| 29 | + git \ |
| 30 | + libslirp-dev \ |
| 31 | + python3-pip \ |
| 32 | + ninja-build \ |
| 33 | + pkg-config \ |
| 34 | + libglib2.0-dev \ |
| 35 | + python3-sphinx \ |
| 36 | + python3-sphinx-rtd-theme \ |
| 37 | + build-essential \ |
| 38 | + flex \ |
| 39 | + bison && \ |
| 40 | + rm -rf /var/lib/apt/lists/* /var/log/* /var/cache/ldconfig/aux-cache |
| 41 | +RUN git clone https://github.com/kvinwang/qemu-tdx.git --depth 1 --branch passthrough-dump-acpi --single-branch && \ |
| 42 | + cd qemu-tdx && git fetch --depth 1 origin ${QEMU_REV} && \ |
| 43 | + git checkout ${QEMU_REV} && \ |
| 44 | + ../config-qemu.sh ./build /usr/local && \ |
| 45 | + cd build && \ |
| 46 | + ninja && \ |
| 47 | + strip qemu-system-x86_64 && \ |
| 48 | + install -m 755 qemu-system-x86_64 /usr/local/bin/dstack-acpi-tables && \ |
| 49 | + cd ../ && \ |
| 50 | + install -d /usr/local/share/qemu && \ |
| 51 | + install -m 644 pc-bios/efi-virtio.rom /usr/local/share/qemu/ && \ |
| 52 | + install -m 644 pc-bios/kvmvapic.bin /usr/local/share/qemu/ && \ |
| 53 | + install -m 644 pc-bios/linuxboot_dma.bin /usr/local/share/qemu/ && \ |
| 54 | + cd .. && rm -rf qemu-tdx |
| 55 | +COPY --from=kms-builder /build/dstack/target/x86_64-unknown-linux-musl/release/dstack-kms /usr/local/bin/dstack-kms |
| 56 | +COPY entrypoint.sh /entrypoint.sh |
| 57 | +COPY .GIT_REV /etc/.GIT_REV |
| 58 | +RUN chmod +x /entrypoint.sh |
| 59 | +ENTRYPOINT ["/entrypoint.sh"] |
| 60 | +CMD ["dstack-kms"] |
0 commit comments