mirror of
https://github.com/songquanpeng/one-api.git
synced 2025-11-13 03:43:44 +08:00
feat: enhance Dockerfile for multi-architecture support; add build commands for ARM64 and update base images
This commit is contained in:
36
Dockerfile
36
Dockerfile
@@ -1,3 +1,5 @@
|
|||||||
|
# * for amd64: docker build -t ppcelery/one-api:arm64-latest .
|
||||||
|
# * for arm64: DOCKER_BUILDKIT=1 docker build --platform linux/arm64 --build-arg TARGETARCH=arm64 -t ppcelery/one-api:arm64-latest .
|
||||||
FROM node:18 AS builder
|
FROM node:18 AS builder
|
||||||
|
|
||||||
WORKDIR /web
|
WORKDIR /web
|
||||||
@@ -13,6 +15,8 @@ RUN npm install --prefix /web/default & \
|
|||||||
npm install --prefix /web/air & \
|
npm install --prefix /web/air & \
|
||||||
wait
|
wait
|
||||||
|
|
||||||
|
RUN mkdir -p /web/build
|
||||||
|
|
||||||
# Build the web projects
|
# Build the web projects
|
||||||
RUN DISABLE_ESLINT_PLUGIN='true' REACT_APP_VERSION=$(cat ./VERSION) npm run build --prefix /web/default & \
|
RUN DISABLE_ESLINT_PLUGIN='true' REACT_APP_VERSION=$(cat ./VERSION) npm run build --prefix /web/default & \
|
||||||
DISABLE_ESLINT_PLUGIN='true' REACT_APP_VERSION=$(cat ./VERSION) npm run build --prefix /web/berry & \
|
DISABLE_ESLINT_PLUGIN='true' REACT_APP_VERSION=$(cat ./VERSION) npm run build --prefix /web/berry & \
|
||||||
@@ -30,12 +34,21 @@ ENV GO111MODULE=on \
|
|||||||
GOOS=linux \
|
GOOS=linux \
|
||||||
GOARCH=${TARGETARCH}
|
GOARCH=${TARGETARCH}
|
||||||
|
|
||||||
|
# Print architecture information for debugging
|
||||||
|
RUN echo "Building for TARGETARCH=${TARGETARCH}" && \
|
||||||
|
echo "Current architecture: $(uname -m)"
|
||||||
|
|
||||||
# For ARM64 builds
|
# For ARM64 builds
|
||||||
RUN if [ "${TARGETARCH}" = "arm64" ]; then \
|
RUN apt-get update && \
|
||||||
apt-get update && apt-get install -y gcc-aarch64-linux-gnu && \
|
if [ "${TARGETARCH}" = "arm64" ]; then \
|
||||||
export CC=aarch64-linux-gnu-gcc; \
|
apt-get install -y gcc-aarch64-linux-gnu && \
|
||||||
|
export CC=aarch64-linux-gnu-gcc && \
|
||||||
|
export GOARCH=arm64 && \
|
||||||
|
export CGO_ENABLED=1 && \
|
||||||
|
# This is critical for ARM64 cross-compilation
|
||||||
|
export CGO_CFLAGS="-g -O2 -fPIC"; \
|
||||||
else \
|
else \
|
||||||
apt-get update && apt-get install -y build-essential; \
|
apt-get install -y build-essential; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Common dependencies
|
# Common dependencies
|
||||||
@@ -51,18 +64,22 @@ RUN go mod download
|
|||||||
COPY . .
|
COPY . .
|
||||||
COPY --from=builder /web/build ./web/build
|
COPY --from=builder /web/build ./web/build
|
||||||
|
|
||||||
# Use the appropriate compiler based on architecture
|
# Simplified build command that handles both architectures
|
||||||
RUN if [ "${TARGETARCH}" = "arm64" ]; then \
|
RUN if [ "${TARGETARCH}" = "arm64" ]; then \
|
||||||
CC=aarch64-linux-gnu-gcc go build -trimpath -ldflags "-s -w -X github.com/songquanpeng/one-api/common.Version=$(cat VERSION)" -o one-api; \
|
CC=aarch64-linux-gnu-gcc \
|
||||||
|
CGO_ENABLED=1 \
|
||||||
|
GOARCH=arm64 \
|
||||||
|
CGO_CFLAGS="-g -O2 -fPIC" \
|
||||||
|
go build -trimpath -ldflags "-s -w -X github.com/songquanpeng/one-api/common.Version=$(cat VERSION)" -o one-api; \
|
||||||
else \
|
else \
|
||||||
go build -trimpath -ldflags "-s -w -X github.com/songquanpeng/one-api/common.Version=$(cat VERSION)" -o one-api; \
|
go build -trimpath -ldflags "-s -w -X github.com/songquanpeng/one-api/common.Version=$(cat VERSION)" -o one-api; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Use a pre-built image that already has ffmpeg for ARM64
|
# Use a pre-built image that already has ffmpeg for ARM64
|
||||||
FROM --platform=$TARGETPLATFORM jrottenberg/ffmpeg:4.3-ubuntu2004 AS ffmpeg
|
FROM --platform=$TARGETPLATFORM jrottenberg/ffmpeg:6.1.2-ubuntu2404 AS ffmpeg
|
||||||
|
|
||||||
# Use Ubuntu as the base image which has better ARM64 support
|
# Use Ubuntu as the base image which has better ARM64 support
|
||||||
FROM --platform=$TARGETPLATFORM ubuntu:20.04
|
FROM --platform=$TARGETPLATFORM ubuntu:24.04
|
||||||
|
|
||||||
ARG TARGETARCH=amd64
|
ARG TARGETARCH=amd64
|
||||||
ENV DEBIAN_FRONTEND=noninteractive
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
@@ -79,6 +96,9 @@ COPY --from=ffmpeg /usr/local/bin/ffprobe /usr/local/bin/
|
|||||||
# Copy our application binary
|
# Copy our application binary
|
||||||
COPY --from=builder2 /build/one-api /
|
COPY --from=builder2 /build/one-api /
|
||||||
|
|
||||||
|
# Create web directory structure and copy web assets
|
||||||
|
COPY --from=builder2 /build/web /web
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
WORKDIR /data
|
WORKDIR /data
|
||||||
ENTRYPOINT ["/one-api"]
|
ENTRYPOINT ["/one-api"]
|
||||||
|
|||||||
Reference in New Issue
Block a user