This commit is contained in:
cangui 2025-07-27 16:45:24 +02:00
parent 3032a06952
commit d3b27eec01
2 changed files with 11 additions and 10 deletions

View File

@ -2,11 +2,18 @@ FROM golang:1.24
WORKDIR /app WORKDIR /app
# Copie les fichiers de dépendances Go
COPY go.mod go.sum ./ COPY go.mod go.sum ./
RUN go mod download RUN go mod download
# Copie tout le reste (code + web + assets)
COPY . . COPY . .
# Build de ton binaire
RUN go build -o shelfy . RUN go build -o shelfy .
# Expose les ports nécessaires
EXPOSE 8080 2121
# Commande de lancement
CMD ["./shelfy"] CMD ["./shelfy"]

View File

@ -2,25 +2,19 @@ version: "3.9"
services: services:
go-app: go-app:
image: golang:1.24 # Image officielle Go 1.24, on build en local build: . # Utilise le Dockerfile (build image locale)
container_name: shelfy-go container_name: shelfy-go
working_dir: /app working_dir: /app
volumes: volumes:
- ./:/app # Code source monté pour le dev (remplace par ./build:/app pour de la prod) - ./upload:/app/upload # Dossier upload persistant (pas rebuild !)
- ./upload:/app/upload # Dossier upload persistant, PAS rebuild - go-modules:/go/pkg/mod # Cache Go modules (optionnel, pour accélérer build)
- go-modules:/go/pkg/mod # Cache des modules Go
ports: ports:
- "8090:8080" # HTTP - "8090:8080" # HTTP exposé en 8090
- "2121:2121" # FTP - "2121:2121" # FTP
command: >
sh -c "go mod tidy &&
go build -o shelfy . &&
./shelfy"
labels: labels:
- traefik.http.routers.shelfy.middlewares=webdav-allow-methods@docker - traefik.http.routers.shelfy.middlewares=webdav-allow-methods@docker
- traefik.http.middlewares.webdav-allow-methods.headers.accesscontrolallowmethods=GET,PUT,POST,DELETE,PROPFIND,OPTIONS,LOCK,UNLOCK,HEAD - traefik.http.middlewares.webdav-allow-methods.headers.accesscontrolallowmethods=GET,PUT,POST,DELETE,PROPFIND,OPTIONS,LOCK,UNLOCK,HEAD
- traefik.http.middlewares.webdav-allow-methods.headers.accesscontrolallowheaders=Authorization,Depth,Content-Type,If-Modified-Since,User-Agent,Destination,Overwrite - traefik.http.middlewares.webdav-allow-methods.headers.accesscontrolallowheaders=Authorization,Depth,Content-Type,If-Modified-Since,User-Agent,Destination,Overwrite
restart: unless-stopped restart: unless-stopped
volumes: volumes: