diff --git a/.forgejo/workflows/deploy.yaml b/.forgejo/workflows/deploy.yaml index a001ae7..1bea78c 100644 --- a/.forgejo/workflows/deploy.yaml +++ b/.forgejo/workflows/deploy.yaml @@ -9,12 +9,11 @@ env: REGISTRY: pipe.gohorsejobs.com IMAGE_NAMESPACE: bohessefm DOCKER_HOST: unix:///run/docker.sock - # ATIVA O BUILDKIT: Necessário para usar --mount (cache) no Dockerfile - DOCKER_BUILDKIT: 1 + # AJUSTE: BuildKit desativado para compatibilidade com o Docker do seu Runner + DOCKER_BUILDKIT: 0 jobs: build-and-push: - # Ajustado para usar as labels que aparecem no seu Runner ID 50 runs-on: [self-hosted, linux-amd64] defaults: run: @@ -31,11 +30,11 @@ jobs: - name: Build & Push Backend run: | - # Build usando BuildKit (suporta o cache do seu Dockerfile) + # Build usando o builder padrão (legacy) docker build -t ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/gohorsejobs:${{ github.sha }} \ -t ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/gohorsejobs:latest ./backend - # Push --quiet evita o flood de logs que derruba o Forgejo + # Push --quiet para não sobrecarregar o banco do Forgejo com logs docker push --quiet ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/gohorsejobs:${{ github.sha }} docker push --quiet ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/gohorsejobs:latest @@ -59,13 +58,18 @@ jobs: - name: Deploy to K3s run: | + # Garante o namespace kubectl create namespace gohorsejobsdev --dry-run=client -o yaml | kubectl apply -f - + + # Aplica os manifestos do diretório kubectl apply -f k8s/dev/ -n gohorsejobsdev + # Atualiza as imagens nos deployments kubectl -n gohorsejobsdev set image deployment/gohorse-backend-dev \ backend=${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/gohorsejobs:${{ github.sha }} kubectl -n gohorsejobsdev set image deployment/gohorse-backoffice-dev \ backoffice=${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/backoffice:${{ github.sha }} + # Aguarda o rollout para confirmar o sucesso kubectl -n gohorsejobsdev rollout status deployment/gohorse-backend-dev --timeout=120s \ No newline at end of file diff --git a/backend/Dockerfile b/backend/Dockerfile index 9af016f..22b298e 100644 --- a/backend/Dockerfile +++ b/backend/Dockerfile @@ -1,34 +1,38 @@ FROM mirror.gcr.io/library/golang:1.24-alpine AS builder +# Ajuste de Mirror e instalação de dependências RUN sed -i 's/dl-cdn.alpinelinux.org/uk.alpinelinux.org/g' /etc/apk/repositories && \ apk add --no-cache git ca-certificates tzdata WORKDIR /build +# Copia apenas os arquivos de dependência primeiro para aproveitar o cache de camadas do Docker COPY go.mod go.sum ./ -# --mount=type=cache permite que o Go use cache de módulos entre builds sem inflar a imagem -RUN --mount=type=cache,target=/go/pkg/mod \ - go mod download && go mod verify +# REMOVIDO --mount: Usando o download padrão compatível com Docker Legacy +RUN go mod download && go mod verify + +# Copia o restante do código fonte COPY . . -# Ajuste: -p 2 para não estressar a CPU do servidor e causar Erro 500 no Forgejo -RUN --mount=type=cache,target=/root/.cache/go-build \ - CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build \ +# Build Otimizado: +# -p 2 para evitar picos de CPU que causam Erro 500 no Forgejo +# REMOVIDO --mount para compatibilidade +RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build \ -p 2 \ -ldflags="-s -w" \ -trimpath \ -o /app/main ./cmd/api +# --- Estágio Final (Imagem de Produção) --- FROM scratch AS runner +# Copia apenas o necessário do builder COPY --from=builder /usr/share/zoneinfo /usr/share/zoneinfo COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ COPY --from=builder /app/main /main COPY --from=builder /build/migrations /migrations -# GOGC=50 é agressivo (bom para economizar RAM), mas aumenta uso de CPU. -# Se o servidor estiver travando por CPU, tente GOGC=100. ENV PORT=8521 \ TZ=America/Sao_Paulo \ GODEBUG=netdns=go \