-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathreplay.Dockerfile
57 lines (39 loc) · 2.13 KB
/
replay.Dockerfile
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
FROM ubuntu:22.04 AS builder
ARG TZ='Etc/UTC'
ARG RUST_TOOLCHAIN='1.73.0'
ARG PHALA_GIT_REPO='https://github.com/Phala-Network/phala-blockchain.git'
ARG PHALA_GIT_TAG='master'
WORKDIR /root
RUN DEBIAN_FRONTEND='noninteractive' apt-get update && \
DEBIAN_FRONTEND='noninteractive' apt-get upgrade -y && \
DEBIAN_FRONTEND='noninteractive' apt-get install -y apt-utils apt-transport-https software-properties-common readline-common curl vim wget gnupg gnupg2 gnupg-agent ca-certificates cmake pkg-config libssl-dev git build-essential llvm clang libclang-dev rsync libboost-all-dev libssl-dev zlib1g-dev miniupnpc protobuf-compiler
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain="${RUST_TOOLCHAIN}" && \
$HOME/.cargo/bin/rustup target add wasm32-unknown-unknown --toolchain "${RUST_TOOLCHAIN}"
RUN git clone --depth 1 --recurse-submodules --shallow-submodules -j 8 -b ${PHALA_GIT_TAG} ${PHALA_GIT_REPO} phala-blockchain
RUN cd $HOME/phala-blockchain && \
PATH="$HOME/.cargo/bin:$PATH" cargo fetch
ARG PHALA_CARGO_PROFILE='release'
RUN cd $HOME/phala-blockchain && \
PATH="$HOME/.cargo/bin:$PATH" cargo build --profile $PHALA_CARGO_PROFILE && \
cp ./target/$PHALA_CARGO_PROFILE/phala-node /root && \
cp ./target/$PHALA_CARGO_PROFILE/pherry /root && \
cp ./target/$PHALA_CARGO_PROFILE/headers-cache /root && \
cp ./target/$PHALA_CARGO_PROFILE/replay /root && \
PATH="$HOME/.cargo/bin:$PATH" cargo clean && \
rm -rf /root/.cargo/registry && \
rm -rf /root/.cargo/git
# ====
FROM ubuntu:22.04
ARG TZ='Etc/UTC'
RUN DEBIAN_FRONTEND='noninteractive' apt-get update && \
DEBIAN_FRONTEND='noninteractive' apt-get upgrade -y && \
DEBIAN_FRONTEND='noninteractive' apt-get install -y apt-utils apt-transport-https software-properties-common readline-common curl vim wget gnupg gnupg2 gnupg-agent ca-certificates git unzip tini
COPY --from=builder /root/replay .
ADD dockerfile.d/start_replay.sh ./start_replay.sh
RUN mkdir /root/data
WORKDIR /root
ENV RUST_LOG="info"
ENV EXTRA_OPTS=''
EXPOSE 8080
ENTRYPOINT ["/usr/bin/tini", "--"]
CMD ["/bin/bash", "./start_replay.sh"]