[Dockerfile] Update toolchains build
This commit is contained in:
parent
198515ab90
commit
88d512586c
2
Makefile
2
Makefile
@ -42,8 +42,6 @@ submodule: githooks init-submodule
|
|||||||
@cp deps/sefs/sefs-cli/lib/libsefs-cli_sim.so build/lib
|
@cp deps/sefs/sefs-cli/lib/libsefs-cli_sim.so build/lib
|
||||||
@cp deps/sefs/sefs-cli/lib/libsefs-cli.signed.so build/lib
|
@cp deps/sefs/sefs-cli/lib/libsefs-cli.signed.so build/lib
|
||||||
@cp deps/sefs/sefs-cli/enclave/Enclave.config.xml build/sefs-cli.Enclave.xml
|
@cp deps/sefs/sefs-cli/enclave/Enclave.config.xml build/sefs-cli.Enclave.xml
|
||||||
@# Build and install Occlum dcap lib
|
|
||||||
@cd tools/toolchains/dcap_lib && ./build.sh
|
|
||||||
else
|
else
|
||||||
submodule: githooks init-submodule
|
submodule: githooks init-submodule
|
||||||
@rm -rf build
|
@rm -rf build
|
||||||
|
@ -130,44 +130,45 @@ RUN wget http://www.etallen.com/cpuid/cpuid-20200211.x86_64.tar.gz && \
|
|||||||
ARG OCCLUM_BRANCH
|
ARG OCCLUM_BRANCH
|
||||||
WORKDIR /root
|
WORKDIR /root
|
||||||
RUN git clone -b $OCCLUM_BRANCH https://github.com/occlum/occlum && \
|
RUN git clone -b $OCCLUM_BRANCH https://github.com/occlum/occlum && \
|
||||||
cp -r /root/occlum/tools/toolchains/* /tmp/ && mkdir -p /opt/occlum/ && \
|
cd /root/occlum && git submodule update --init && \
|
||||||
|
mkdir -p /opt/occlum/ && \
|
||||||
cp /root/occlum/tools/docker/start_aesm.sh /opt/occlum/
|
cp /root/occlum/tools/docker/start_aesm.sh /opt/occlum/
|
||||||
|
|
||||||
# Install Occlum toolchain
|
# Install Occlum toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd musl-gcc && ./build.sh && ./install_zlib.sh && rm -rf /tmp/musl-gcc
|
RUN cd musl-gcc && ./build.sh && ./install_zlib.sh
|
||||||
ENV PATH="/opt/occlum/build/bin:/usr/local/occlum/bin:$PATH"
|
ENV PATH="/opt/occlum/build/bin:/usr/local/occlum/bin:$PATH"
|
||||||
|
|
||||||
# Install glibc
|
# Install glibc
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd glibc && ./build.sh && rm -rf /tmp/glibc
|
RUN cd glibc && ./build.sh
|
||||||
|
|
||||||
# Install Occlum Golang toolchain
|
# Install Occlum Golang toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd golang && ./build.sh && rm -rf /tmp/golang
|
RUN cd golang && ./build.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/golang/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/golang/bin:$PATH"
|
||||||
|
|
||||||
# Install Occlum Rust toolchain
|
# Install Occlum Rust toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd rust && ./build.sh && rm -rf /tmp/rust
|
RUN cd rust && ./build.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/rust/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/rust/bin:$PATH"
|
||||||
ENV LD_LIBRARY_PATH="/opt/intel/sgxsdk/sdk_libs"
|
ENV LD_LIBRARY_PATH="/opt/intel/sgxsdk/sdk_libs"
|
||||||
|
|
||||||
# Install Occlum bash
|
# Install Occlum bash
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd bash && ./build.sh && rm -rf /tmp/bash
|
RUN cd bash && ./build.sh
|
||||||
|
|
||||||
# Install Occlum busybox
|
# Install Occlum busybox
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd busybox && ./build.sh && rm -rf /tmp/busybox
|
RUN cd busybox && ./build.sh
|
||||||
|
|
||||||
# Install Occlum Java toolchain (JDK 11)
|
# Install Occlum Java toolchain (JDK 11)
|
||||||
ARG JDK11_PATH=/opt/occlum/toolchains/jvm/java-11-openjdk
|
ARG JDK11_PATH=/opt/occlum/toolchains/jvm/java-11-openjdk
|
||||||
COPY --from=alpine /usr/lib/jvm/java-11-openjdk $JDK11_PATH
|
COPY --from=alpine /usr/lib/jvm/java-11-openjdk $JDK11_PATH
|
||||||
RUN rm $JDK11_PATH/lib/security/cacerts
|
RUN rm $JDK11_PATH/lib/security/cacerts
|
||||||
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK11_PATH/lib/security/cacerts
|
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK11_PATH/lib/security/cacerts
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd java && ./install_dragonwell.sh && rm -rf /tmp/java
|
RUN cd java && ./install_dragonwell.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/jvm/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/jvm/bin:$PATH"
|
||||||
|
|
||||||
# Install OpenJDK 8
|
# Install OpenJDK 8
|
||||||
@ -176,6 +177,18 @@ COPY --from=alpine /usr/lib/jvm/java-1.8-openjdk $JDK8_PATH
|
|||||||
RUN rm $JDK8_PATH/jre/lib/security/cacerts
|
RUN rm $JDK8_PATH/jre/lib/security/cacerts
|
||||||
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK8_PATH/jre/lib/security/cacerts
|
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK8_PATH/jre/lib/security/cacerts
|
||||||
|
|
||||||
|
# Install DCAP library
|
||||||
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
|
RUN cd dcap_lib && ./build.sh
|
||||||
|
|
||||||
|
# Install AECS Client library
|
||||||
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
|
RUN cd aecs_client && ./build.sh
|
||||||
|
|
||||||
|
# Install GRPC RATLS
|
||||||
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
|
RUN cd grpc_ratls && ./build.sh
|
||||||
|
|
||||||
# Build and install Occlum
|
# Build and install Occlum
|
||||||
WORKDIR /root
|
WORKDIR /root
|
||||||
RUN cd occlum && \
|
RUN cd occlum && \
|
||||||
|
@ -137,44 +137,45 @@ RUN git clone -b sgx_2.17.1_for_occlum https://github.com/occlum/linux-sgx && \
|
|||||||
ARG OCCLUM_BRANCH
|
ARG OCCLUM_BRANCH
|
||||||
WORKDIR /root
|
WORKDIR /root
|
||||||
RUN git clone -b $OCCLUM_BRANCH https://github.com/occlum/occlum && \
|
RUN git clone -b $OCCLUM_BRANCH https://github.com/occlum/occlum && \
|
||||||
cp -r /root/occlum/tools/toolchains/* /tmp/ && mkdir -p /opt/occlum/ && \
|
cd /root/occlum && git submodule update --init && \
|
||||||
|
mkdir -p /opt/occlum/ && \
|
||||||
cp /root/occlum/tools/docker/start_aesm.sh /opt/occlum/
|
cp /root/occlum/tools/docker/start_aesm.sh /opt/occlum/
|
||||||
|
|
||||||
# Install Occlum toolchain
|
# Install Occlum toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd musl-gcc && ./build.sh && ./install_zlib.sh && rm -rf /tmp/musl-gcc
|
RUN cd musl-gcc && ./build.sh && ./install_zlib.sh
|
||||||
ENV PATH="/opt/occlum/build/bin:/usr/local/occlum/bin:$PATH"
|
ENV PATH="/opt/occlum/build/bin:/usr/local/occlum/bin:$PATH"
|
||||||
|
|
||||||
# Install glibc
|
# Install glibc
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd glibc && ./build.sh && rm -rf /tmp/glibc
|
RUN cd glibc && ./build.sh
|
||||||
|
|
||||||
# Install Occlum Golang toolchain
|
# Install Occlum Golang toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd golang && ./build.sh && rm -rf /tmp/golang
|
RUN cd golang && ./build.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/golang/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/golang/bin:$PATH"
|
||||||
|
|
||||||
# Install Occlum Rust toolchain
|
# Install Occlum Rust toolchain
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd rust && ./build.sh && rm -rf /tmp/rust
|
RUN cd rust && ./build.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/rust/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/rust/bin:$PATH"
|
||||||
ENV LD_LIBRARY_PATH="/opt/intel/sgxsdk/sdk_libs"
|
ENV LD_LIBRARY_PATH="/opt/intel/sgxsdk/sdk_libs"
|
||||||
|
|
||||||
# Install Occlum bash
|
# Install Occlum bash
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd bash && ./build.sh && rm -rf /tmp/bash
|
RUN cd bash && ./build.sh
|
||||||
|
|
||||||
# Install Occlum busybox
|
# Install Occlum busybox
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd busybox && ./build.sh && rm -rf /tmp/busybox
|
RUN cd busybox && ./build.sh
|
||||||
|
|
||||||
# Install Occlum Java toolchain (JDK 11)
|
# Install Occlum Java toolchain (JDK 11)
|
||||||
ARG JDK11_PATH=/opt/occlum/toolchains/jvm/java-11-openjdk
|
ARG JDK11_PATH=/opt/occlum/toolchains/jvm/java-11-openjdk
|
||||||
COPY --from=alpine /usr/lib/jvm/java-11-openjdk $JDK11_PATH
|
COPY --from=alpine /usr/lib/jvm/java-11-openjdk $JDK11_PATH
|
||||||
RUN rm $JDK11_PATH/lib/security/cacerts
|
RUN rm $JDK11_PATH/lib/security/cacerts
|
||||||
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK11_PATH/lib/security/cacerts
|
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK11_PATH/lib/security/cacerts
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd java && ./install_dragonwell.sh && rm -rf /tmp/java
|
RUN cd java && ./install_dragonwell.sh
|
||||||
ENV PATH="/opt/occlum/toolchains/jvm/bin:$PATH"
|
ENV PATH="/opt/occlum/toolchains/jvm/bin:$PATH"
|
||||||
|
|
||||||
# Install OpenJDK 8
|
# Install OpenJDK 8
|
||||||
@ -183,9 +184,17 @@ COPY --from=alpine /usr/lib/jvm/java-1.8-openjdk $JDK8_PATH
|
|||||||
RUN rm $JDK8_PATH/jre/lib/security/cacerts
|
RUN rm $JDK8_PATH/jre/lib/security/cacerts
|
||||||
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK8_PATH/jre/lib/security/cacerts
|
COPY --from=alpine /etc/ssl/certs/java/cacerts $JDK8_PATH/jre/lib/security/cacerts
|
||||||
|
|
||||||
|
# Install DCAP library
|
||||||
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
|
RUN cd dcap_lib && ./build.sh
|
||||||
|
|
||||||
# Install AECS Client library
|
# Install AECS Client library
|
||||||
WORKDIR /tmp
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
RUN cd aecs_client && ./build.sh && rm -rf /tmp/aecs_client
|
RUN cd aecs_client && ./build.sh
|
||||||
|
|
||||||
|
# Install GRPC RATLS
|
||||||
|
WORKDIR /root/occlum/tools/toolchains
|
||||||
|
RUN cd grpc_ratls && ./build.sh
|
||||||
|
|
||||||
# Install Occlum
|
# Install Occlum
|
||||||
WORKDIR /root
|
WORKDIR /root
|
||||||
@ -197,11 +206,6 @@ RUN cd occlum && \
|
|||||||
cp -r demos /root/demos && \
|
cp -r demos /root/demos && \
|
||||||
rm -rf /root/occlum
|
rm -rf /root/occlum
|
||||||
|
|
||||||
# Install GRPC RATLS
|
|
||||||
# Do after installing Occlum is because it depends on the dcap library.
|
|
||||||
WORKDIR /tmp
|
|
||||||
RUN cd grpc_ratls && ./build.sh && rm -rf /tmp/grpc_ratls
|
|
||||||
|
|
||||||
# Start AESM service automatically
|
# Start AESM service automatically
|
||||||
#
|
#
|
||||||
# To do so, we add the script to ~/.bashrc. We cannot use systemd to run AESM
|
# To do so, we add the script to ~/.bashrc. We cannot use systemd to run AESM
|
||||||
|
Loading…
Reference in New Issue
Block a user