52 lines
1.9 KiB
Docker
52 lines
1.9 KiB
Docker
FROM rust:1.91-slim-bookworm AS builder
|
|
WORKDIR /usr/src/app
|
|
|
|
# 官方 Rust 镜像中 CARGO_HOME = /usr/local/cargo
|
|
RUN echo '[source.crates-io]' > $CARGO_HOME/config.toml \
|
|
&& echo 'replace-with = "rsproxy-sparse"' >> $CARGO_HOME/config.toml \
|
|
&& echo '[source.rsproxy]' >> $CARGO_HOME/config.toml \
|
|
&& echo 'registry = "https://rsproxy.cn/crates.io-index"' >> $CARGO_HOME/config.toml \
|
|
&& echo '[source.rsproxy-sparse]' >> $CARGO_HOME/config.toml \
|
|
&& echo 'registry = "sparse+https://rsproxy.cn/index/"' >> $CARGO_HOME/config.toml \
|
|
&& echo '[registries.rsproxy]' >> $CARGO_HOME/config.toml \
|
|
&& echo 'index = "https://rsproxy.cn/crates.io-index"' >> $CARGO_HOME/config.toml
|
|
|
|
# 验证一下文件是否真的存在(构建时会在 log 打印出来,让你放心)
|
|
RUN cat $CARGO_HOME/config.toml
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends ca-certificates pkg-config libssl-dev git openssh-client \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY Cargo.toml Cargo.lock ./
|
|
COPY .cargo ./.cargo
|
|
RUN mkdir -p src && echo "fn main() {}" > src/main.rs
|
|
RUN cargo build --release --locked
|
|
|
|
COPY src ./src
|
|
COPY docs ./docs
|
|
RUN touch src/main.rs
|
|
RUN cargo build --release --locked
|
|
|
|
FROM debian:bookworm-slim AS runner
|
|
WORKDIR /app
|
|
|
|
RUN sed -i 's/deb.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.list.d/debian.sources \
|
|
&& sed -i 's/security.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.list.d/debian.sources
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends ca-certificates libssl3 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
RUN groupadd --system --gid 10001 iam \
|
|
&& useradd --system --uid 10001 --gid 10001 --no-create-home --shell /usr/sbin/nologin iam \
|
|
&& mkdir -p /app/log /app/data \
|
|
&& chown -R iam:iam /app/log
|
|
|
|
ENV PORT=5020
|
|
EXPOSE 5020
|
|
|
|
COPY --from=builder /usr/src/app/target/release/iam-service /app/iam-service
|
|
USER iam
|
|
CMD ["/app/iam-service"]
|