This commit is contained in:
Tao Chen
2024-10-29 14:27:15 +08:00
parent 4105f14a3f
commit 461b100b6c
3 changed files with 60 additions and 21 deletions

View File

@@ -1,4 +1,26 @@
# Ignore Docker Compose configuration files
docker-compose.yaml docker-compose.yaml
Dcokerfile
Dcokerfile.dev # Ignore development Dockerfile
data Dockerfile.dev
# Ignore the data directory
data/
# Ignore version control system directories
.git/
# Ignore log and temporary files
*.log
*.tmp
*.swp
# Ignore editor/IDE configuration files
.vscode/
.idea/
# Ignore binaries and build cache
release/
bin/
*.exe
*.out

View File

@@ -1,36 +1,50 @@
# Use build arguments for Go version and architecture # Use build arguments for Go version and architecture
ARG GO_VERSION=1.23.2 ARG GO_VERSION=1.22
ARG BUILDARCH ARG BUILDARCH=amd64
# Stage 1: Build the Go application with swag # Stage 1: Builder Stage
FROM golang:${GO_VERSION} AS builder # FROM golang:${GO_VERSION}-alpine AS builder
FROM crazymax/xgo:${GO_VERSION} AS builder
# Set up working directory # Set up working directory
WORKDIR /app WORKDIR /app
# Install dependencies and copy the source code # Step 1: Copy the source code
COPY go.mod ./
RUN go install github.com/swaggo/swag/cmd/swag@latest
RUN go mod download
COPY . . COPY . .
#run the build script # Step 2: Download dependencies
RUN chmod +x build.sh && ./build.sh RUN go mod tidy && go mod download
# Stage 2: Prepare the final image
# Step 3: Install swag and Run the build script
RUN go install github.com/swaggo/swag/cmd/swag@latest && \
swag init -g cmd/apimain.go --output docs/api --instanceName api --exclude http/controller/admin && \
swag init -g cmd/apimain.go --output docs/admin --instanceName admin --exclude http/controller/api
# Build the Go application with CGO enabled and specified ldflags
RUN CGO_ENABLED=1 GOOS=linux go build -a \
-ldflags "-s -w --extldflags '-static -fpic'" \
-installsuffix cgo -o release/apimain cmd/apimain.go
# Stage 2: Final Image
FROM alpine:latest FROM alpine:latest
# Set up working directory # Set up working directory
WORKDIR /app WORKDIR /app
# Install necessary dependencies # Install necessary runtime dependencies
RUN apk add --no-cache tzdata file RUN apk add --no-cache tzdata file
# Copy the built application from the builder stage # Copy the built application and resources from the builder stage
COPY --from=builder /app/release /app/ COPY --from=builder /app/release /app/
COPY --from=builder /app/conf /app/conf/
COPY --from=builder /app/resources /app/resources/
# Ensure the binary is correctly built # Ensure the binary is correctly built and linked
RUN file /app/apimain RUN file /app/apimain && \
mkdir -p /app/data && \
mkdir -p /app/runtime
# Set up a volume for persistent data # Set up a volume for persistent data
VOLUME /app/data VOLUME /app/data
@@ -39,4 +53,4 @@ VOLUME /app/data
EXPOSE 21114 EXPOSE 21114
# Define the command to run the application # Define the command to run the application
CMD ["app/apimain"] CMD ["./apimain"]

View File

@@ -3,17 +3,20 @@ services:
build: build:
context: . context: .
dockerfile: Dockerfile.dev dockerfile: Dockerfile.dev
args:
- DOCS=""
image: lejianwen/rustdesk-api image: lejianwen/rustdesk-api
container_name: rustdesk-api container_name: rustdesk-api
environment: environment:
- TZ=Asia/Shanghai - TZ=Asia/Shanghai
- RUSTDESK_API_RUSTDESK_ID_SERVER=192.168.1.66:21116 - RUSTDESK_API_RUSTDESK_ID_SERVER=192.168.1.66:21116
- RUSTDESK_API_RUSTDESK_RELAY_SERVER=192.168.1.66:21117 - RUSTDESK_API_RUSTDESK_RELAY_SERVER=192.168.1.66:21117
- RUSTDESK_API_RUSTDESK_API_SERVER=http://192.168.1.66:21114 - RUSTDESK_API_RUSTDESK_API_SERVER=http://localhost:21114
- RUSTDESK_API_RUSTDESK_KEY=123456789 - RUSTDESK_API_RUSTDESK_KEY=123456789
ports: ports:
- 21114:21114 - 21114:21114
volumes: volumes:
- ./data/rustdesk/api:/app/data #将数据库挂载出来方便备份 - ./data/rustdesk/api:/app/data #将数据库挂载出来方便备份
# - ./conf:/app/conf # config
restart: unless-stopped restart: unless-stopped
command: sleep infnite # command: sleep infnite