mirror of
https://github.com/router-for-me/CLIProxyAPI.git
synced 2026-05-31 20:02:36 +08:00
feat: add local Docker build script and update compose configuration
- Introduced a new script `docker-build-local.sh` to build a local Docker image and start services using Docker Compose. - Updated `docker-compose.yml` to allow dynamic pull policy configuration via the `CLI_PROXY_PULL_POLICY` environment variable. - Modified `Dockerfile` to support build arguments for Go module proxy settings during the `go mod download` step.
This commit is contained in:
@@ -4,7 +4,12 @@ WORKDIR /app
|
||||
|
||||
COPY go.mod go.sum ./
|
||||
|
||||
RUN go mod download
|
||||
ARG GOPROXY=https://proxy.golang.org,direct
|
||||
ARG GOSUMDB=sum.golang.org
|
||||
ARG GOPRIVATE=
|
||||
|
||||
RUN GOPROXY="${GOPROXY}" GOSUMDB="${GOSUMDB}" GOPRIVATE="${GOPRIVATE}" go mod download || \
|
||||
GOPROXY="https://goproxy.cn,direct" GOSUMDB="sum.golang.google.cn" GOPRIVATE="${GOPRIVATE}" go mod download
|
||||
|
||||
COPY . .
|
||||
|
||||
|
||||
50
docker-build-local.sh
Executable file
50
docker-build-local.sh
Executable file
@@ -0,0 +1,50 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
# Build local image with docker build (no buildx required),
|
||||
# then start services via docker compose.
|
||||
|
||||
set -euo pipefail
|
||||
|
||||
if ! command -v docker >/dev/null 2>&1; then
|
||||
echo "Error: docker command not found."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! docker compose version >/dev/null 2>&1; then
|
||||
echo "Error: docker compose plugin not available."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
IMAGE_TAG="${CLI_PROXY_IMAGE:-cli-proxy-api:local}"
|
||||
|
||||
if git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
|
||||
VERSION="$(git describe --tags --always --dirty)"
|
||||
COMMIT="$(git rev-parse --short HEAD)"
|
||||
else
|
||||
VERSION="dev"
|
||||
COMMIT="none"
|
||||
fi
|
||||
BUILD_DATE="$(date -u +%Y-%m-%dT%H:%M:%SZ)"
|
||||
|
||||
echo "Building local image with:"
|
||||
echo " Image Tag: ${IMAGE_TAG}"
|
||||
echo " Version: ${VERSION}"
|
||||
echo " Commit: ${COMMIT}"
|
||||
echo " Build Date: ${BUILD_DATE}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
docker build \
|
||||
-t "${IMAGE_TAG}" \
|
||||
--build-arg VERSION="${VERSION}" \
|
||||
--build-arg COMMIT="${COMMIT}" \
|
||||
--build-arg BUILD_DATE="${BUILD_DATE}" \
|
||||
--build-arg GOPROXY="${GOPROXY:-https://proxy.golang.org,direct}" \
|
||||
--build-arg GOSUMDB="${GOSUMDB:-sum.golang.org}" \
|
||||
--build-arg GOPRIVATE="${GOPRIVATE:-}" \
|
||||
.
|
||||
|
||||
echo "Starting services from local image..."
|
||||
CLI_PROXY_IMAGE="${IMAGE_TAG}" CLI_PROXY_PULL_POLICY="never" docker compose up -d --remove-orphans --no-build --pull never
|
||||
|
||||
echo "Done."
|
||||
echo "Use 'docker compose logs -f' to view logs."
|
||||
@@ -1,7 +1,7 @@
|
||||
services:
|
||||
cli-proxy-api:
|
||||
image: ${CLI_PROXY_IMAGE:-eceasy/cli-proxy-api:latest}
|
||||
pull_policy: always
|
||||
pull_policy: ${CLI_PROXY_PULL_POLICY:-always}
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
|
||||
Reference in New Issue
Block a user